///*******************************************************************************
// * Copyright (c) 2000, 2010 IBM Corporation and others.
// * All rights reserved. This program and the accompanying materials
// * are made available under the terms of the Eclipse Public License v1.0
// * which accompanies this distribution, and is available at
// * http://www.eclipse.org/legal/epl-v10.html
// *
// * Contributors:
// * IBM Corporation - initial API and implementation
// *******************************************************************************/
//package org.eclipse.ui.tests.api;
//
//import java.util.ArrayList;
//import java.util.Arrays;
//import java.util.HashMap;
//import java.util.HashSet;
//import java.util.List;
//import java.util.Set;
//
//import org.eclipse.core.commands.Command;
//import org.eclipse.core.commands.ExecutionException;
//import org.eclipse.core.commands.NotEnabledException;
//import org.eclipse.core.commands.NotHandledException;
//import org.eclipse.core.commands.ParameterizedCommand;
//import org.eclipse.core.commands.common.NotDefinedException;
//import org.eclipse.core.resources.IFile;
//import org.eclipse.core.resources.IMarker;
//import org.eclipse.core.resources.IProject;
//import org.eclipse.core.resources.IResource;
//import org.eclipse.core.runtime.IAdaptable;
//import org.eclipse.core.runtime.ILogListener;
//import org.eclipse.core.runtime.IStatus;
//import org.eclipse.core.runtime.Platform;
//import org.eclipse.jface.text.IDocument;
//import org.eclipse.jface.util.IPropertyChangeListener;
//import org.eclipse.jface.util.PropertyChangeEvent;
//import org.eclipse.ui.IEditorInput;
//import org.eclipse.ui.IEditorPart;
//import org.eclipse.ui.IEditorReference;
//import org.eclipse.ui.IMemento;
//import org.eclipse.ui.IPageLayout;
//import org.eclipse.ui.IPartListener2;
//import org.eclipse.ui.IPerspectiveDescriptor;
//import org.eclipse.ui.IPerspectiveRegistry;
//import org.eclipse.ui.IViewPart;
//import org.eclipse.ui.IViewReference;
//import org.eclipse.ui.IWorkbenchCommandConstants;
//import org.eclipse.ui.IWorkbenchPage;
//import org.eclipse.ui.IWorkbenchPartReference;
//import org.eclipse.ui.IWorkbenchWindow;
//import org.eclipse.ui.IWorkingSet;
//import org.eclipse.ui.IWorkingSetManager;
//import org.eclipse.ui.PartInitException;
//import org.eclipse.ui.PlatformUI;
//import org.eclipse.ui.WorkbenchException;
//import org.eclipse.ui.XMLMemento;
//import org.eclipse.ui.commands.ICommandService;
//import org.eclipse.ui.editors.text.EditorsUI;
//import org.eclipse.ui.editors.text.TextEditor;
//import org.eclipse.ui.handlers.IHandlerService;
//import org.eclipse.ui.ide.IDE;
//import org.eclipse.ui.internal.WorkbenchPlugin;
//import org.eclipse.ui.internal.tweaklets.Tweaklets;
//import org.eclipse.ui.internal.util.Util;
//import org.eclipse.ui.navigator.resources.ProjectExplorer;
//import org.eclipse.ui.part.FileEditorInput;
//import org.eclipse.ui.part.IPage;
//import org.eclipse.ui.tests.harness.util.CallHistory;
//import org.eclipse.ui.tests.harness.util.EmptyPerspective;
//import org.eclipse.ui.tests.harness.util.FileUtil;
//import org.eclipse.ui.tests.harness.util.UITestCase;
//import org.eclipse.ui.tests.helpers.TestFacade;
//import org.eclipse.ui.texteditor.ITextEditor;
//import org.eclipse.ui.views.contentoutline.ContentOutline;
//
//public class IWorkbenchPageTest extends UITestCase {
//
// private IWorkbenchPage fActivePage;
//
// private IWorkbenchWindow fWin;
//
// private IProject proj;
//
// private int logCount;
// private IStatus logStatus;
// String getMessage() {
// return logStatus==null?"No message":logStatus.getMessage();
// }
// ILogListener openAndHideListener = new ILogListener() {
// public void logging(IStatus status, String plugin) {
// logStatus = status;
// logCount++;
// }
// };
//
//
// private int partHiddenCount = 0;
// private IWorkbenchPartReference partHiddenRef = null;
// private int partVisibleCount = 0;
// private IWorkbenchPartReference partVisibleRef = null;
// private int partActiveCount = 0;
// private IWorkbenchPartReference partActiveRef = null;
// IPartListener2 partListener2 = new IPartListener2() {
// public void partActivated(IWorkbenchPartReference partRef) {
// partActiveCount++;
// partActiveRef = partRef;
// }
//
// public void partBroughtToTop(IWorkbenchPartReference partRef) {
// }
//
// public void partClosed(IWorkbenchPartReference partRef) {
// }
//
// public void partDeactivated(IWorkbenchPartReference partRef) {
// }
//
// public void partHidden(IWorkbenchPartReference partRef) {
// partHiddenCount++;
// partHiddenRef = partRef;
// }
//
// public void partInputChanged(IWorkbenchPartReference partRef) {
// }
//
// public void partOpened(IWorkbenchPartReference partRef) {
// }
//
// public void partVisible(IWorkbenchPartReference partRef) {
// partVisibleCount++;
// partVisibleRef = partRef;
// }
// };
//
// private TestFacade facade;
//
//
//
// public IWorkbenchPageTest(String testName) {
// super(testName);
// }
//
// protected void doSetUp() throws Exception {
// super.doSetUp();
// fWin = openTestWindow();
// fActivePage = fWin.getActivePage();
// logStatus = null;
// logCount = 0;
// facade = (TestFacade) Tweaklets.get(TestFacade.KEY);
// Platform.addLogListener(openAndHideListener);
// }
//
// protected void doTearDown() throws Exception {
// super.doTearDown();
// if (proj != null) {
// FileUtil.deleteProject(proj);
// proj = null;
// }
// Platform.removeLogListener(openAndHideListener);
// }
//
// /**
// * Tests the new working set API.
// *
// * @since 3.2
// */
// public void testWorkingSets1() {
// IWorkbenchPage page = fActivePage;
// IWorkingSet[] sets = page.getWorkingSets();
// assertNotNull(sets);
// assertEquals(0, sets.length);
//
// IWorkingSetManager manager = page.getWorkbenchWindow().getWorkbench()
// .getWorkingSetManager();
//
// IWorkingSet set1 = null, set2 = null;
// try {
// set1 = manager.createWorkingSet("w1", new IAdaptable[0]);
// manager.addWorkingSet(set1);
// set2 = manager.createWorkingSet("w2", new IAdaptable[0]);
// manager.addWorkingSet(set2);
//
// page.setWorkingSets(new IWorkingSet[] { set1 });
// sets = page.getWorkingSets();
//
// assertNotNull(sets);
// assertEquals(1, sets.length);
// assertEquals(set1, sets[0]);
//
// page.setWorkingSets(new IWorkingSet[0]);
// sets = page.getWorkingSets();
// assertNotNull(sets);
// assertEquals(0, sets.length);
//
// page.setWorkingSets(new IWorkingSet[] { set1, set2 });
// sets = page.getWorkingSets();
//
// assertNotNull(sets);
// assertEquals(2, sets.length);
// Set realSet = new HashSet(Arrays.asList(sets));
// assertTrue(realSet.contains(set1));
// assertTrue(realSet.contains(set2));
//
// page.setWorkingSets(new IWorkingSet[0]);
// sets = page.getWorkingSets();
// assertNotNull(sets);
// assertEquals(0, sets.length);
// } finally {
// if (set1 != null)
// manager.removeWorkingSet(set1);
// if (set2 != null)
// manager.removeWorkingSet(set2);
// }
// }
//
// /**
// * Tests the new working set API.
// *
// * @since 3.2
// */
// public void testWorkingSets2() {
// fActivePage.setWorkingSets(null);
// IWorkingSet[] sets = fActivePage.getWorkingSets();
// assertNotNull(sets);
// assertEquals(0, sets.length);
// }
//
// /**
// * Tests the working set listeners.
// *
// * @since 3.2
// */
// public void testWorkingSets3() {
// IWorkingSetManager manager = fActivePage.getWorkbenchWindow()
// .getWorkbench().getWorkingSetManager();
//
// IWorkingSet set1 = null;
// final IWorkingSet[][] sets = new IWorkingSet[1][];
// sets[0] = new IWorkingSet[0];
// IPropertyChangeListener listener = new IPropertyChangeListener() {
//
// public void propertyChange(PropertyChangeEvent event) {
// IWorkingSet[] oldSets = (IWorkingSet[]) event.getOldValue();
// assertTrue(Arrays.equals(sets[0], oldSets));
// sets[0] = (IWorkingSet[]) event.getNewValue();
// }
// };
// try {
// set1 = manager.createWorkingSet("w1", new IAdaptable[0]);
// manager.addWorkingSet(set1);
//
// fActivePage.addPropertyChangeListener(listener);
//
// fActivePage.setWorkingSets(new IWorkingSet[] { set1 });
// fActivePage.setWorkingSets(new IWorkingSet[] {});
// fActivePage.setWorkingSets(new IWorkingSet[] { set1 });
//
// sets[0] = fActivePage.getWorkingSets();
//
// assertNotNull(sets[0]);
// assertEquals(1, sets[0].length);
// assertEquals(set1, sets[0][0]);
//
// } finally {
// fActivePage.removePropertyChangeListener(listener);
// if (set1 != null)
// manager.removeWorkingSet(set1);
// }
// }
//
// /**
// * Test the VIEW_VISIBLE parameter for showView, opening the view in the
// * stack that does not contain the active view. Ensures that the created
// * view is not the active part but is the top part in its stack.
// */
// public void testView_VISIBLE2() throws PartInitException {
// fActivePage.setPerspective(WorkbenchPlugin.getDefault()
// .getPerspectiveRegistry().findPerspectiveWithId(
// "org.eclipse.ui.tests.api.ViewPerspective"));
//
// // create a part to be active
// IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
//
// IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
// IWorkbenchPage.VIEW_VISIBLE);
//
// IViewPart[] stack = fActivePage.getViewStack(createdPart);
// assertEquals(2, stack.length);
//
// assertEquals(createdPart, stack[0]);
// assertEquals(fActivePage.findView(MockViewPart.ID), stack[1]);
//
// assertTrue(fActivePage.isPartVisible(createdPart));
//
// assertEquals(activePart, fActivePage.getActivePart());
// }
//
// /**
// * openEditor(IEditorInput input, String editorId, boolean activate)
// */
// public void testOpenEditor4() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// final String id = MockEditorPart.ID1;
// IEditorInput input = new FileEditorInput(FileUtil.createFile(
// "test.mock1", proj));
// MockPartListener listener = new MockPartListener();
// fActivePage.addPartListener(listener);
// CallHistory callTrace = listener.getCallHistory();
//
// /*
// * javadoc: The editor type is determined by mapping editorId to an
// * editor extension registered with the workbench. javadoc: If activate ==
// * true the editor will be activated
// */
// // open an editor with activation
// // Start with a view active in order to verify that the editor gets
// // activated
// fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
// IWorkbenchPage.VIEW_ACTIVATE);
// callTrace.clear();
// IEditorPart editor = IDE.openEditor(fActivePage, input, id, true);
// assertEquals(editor.getEditorInput(), input);
// assertEquals(editor.getSite().getId(), id);
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
// assertEquals(callTrace.contains("partActivated"), true);
//
// // we need another editor so that the editor under test can receive
// // events.
// // otherwise, events will be ignored.
// IEditorPart extra = IDE.openEditor(fActivePage, FileUtil.createFile(
// "aaaaa", proj));
//
// // close the first editor after the second has opened; necessary for
// // test to work with fix to PR 7743
// fActivePage.closeEditor(editor, false);
//
// // Start with a view active in order to verify that the editor does not
// // get activated
// // (note: regardless of the activate=false flag, the editor would always
// // be activated
// // if it is being opened in the same stack as the active editor. Making
// // a view active
// // initially tests the function of the activate flag)
// fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
// IWorkbenchPage.VIEW_ACTIVATE);
// callTrace.clear();
// // open an editor without activation
// editor = IDE.openEditor(fActivePage, input, id, false);
//
// assertEquals(editor.getEditorInput(), input);
// assertEquals(editor.getSite().getId(), id);
// assertEquals(hasEditor(editor), true);
// assertEquals(callTrace.contains("partActivated"), false);
// assertEquals(callTrace.contains("partBroughtToTop"), true);
//
// fActivePage.activate(extra);
//
// /*
// * javadoc: If this page already has an editor open on the target object
// * that editor is brought to the front
// */
// // open the editor under test second time without activation
// fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
// IWorkbenchPage.VIEW_ACTIVATE);
// callTrace.clear();
// assertEquals(IDE.openEditor(fActivePage, input, id, false), editor);
// assertEquals(callTrace.contains("partBroughtToTop"), true);
// assertEquals(callTrace.contains("partActivated"), false);
//
// // activate the other editor
// fActivePage.activate(extra);
//
// /*
// * javadoc: If activate == true the editor will be activated
// */
// // open the editor under test second time with activation
// fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
// IWorkbenchPage.VIEW_ACTIVATE);
// callTrace.clear();
// assertEquals(IDE.openEditor(fActivePage, input, id, true), editor);
// assertEquals(callTrace.contains("partBroughtToTop"), true);
// assertEquals(callTrace.contains("partActivated"), true);
//
// /*
// * javadoc: If activate == false but another editor in the same stack
// * was active, the new editor will be activated regardless.
// */
// // Close the old editor
// fActivePage.closeEditor(editor, false);
// // Ensure another editor in the stack is active
// fActivePage.activate(extra);
// callTrace.clear();
// // Verify that the editor is still activated
// IDE.openEditor(fActivePage, input, id, false);
// assertEquals(callTrace.contains("partBroughtToTop"), true);
// assertEquals(callTrace.contains("partActivated"), true);
// }
//
// /**
// * tests both of the following: setEditorAreaVisible() isEditorAreaVisible()
// */
// public void testGet_SetEditorAreaVisible() throws Throwable {
// fActivePage.setEditorAreaVisible(true);
// assertTrue(fActivePage.isEditorAreaVisible() == true);
//
// fActivePage.setEditorAreaVisible(false);
// assertTrue(fActivePage.isEditorAreaVisible() == false);
// }
//
// /**
// * openEditor(IWorkbenchPage page, IFile input)
// */
// public void testOpenEditor() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
//
// /*
// * javadoc: 1. The workbench editor registry is consulted to determine
// * if an editor extension has been registered for the file type. If so,
// * an instance of the editor extension is opened on the file
// */
// IFile file = FileUtil.createFile("test.mock1", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file);
//
// boolean foundEditor = hasEditor(editor);
// assertEquals(foundEditor, true);
// assertEquals(fActivePage.getActiveEditor(), editor);
// assertEquals(editor.getSite().getId(), fWorkbench.getEditorRegistry()
// .getDefaultEditor(file.getName()).getId());
//
// /*
// * javadoc: 2. Next, the native operating system will be consulted to
// * determine if a native editor exists for the file type. If so, a new
// * process is started and the native editor is opened on the file.
// */
// // can not be tested
// /*
// * javadoc: 3. If all else fails the file will be opened in a default
// * text editor.
// */
//
// file = FileUtil.createFile("a.null and void", proj);
// editor = IDE.openEditor(fActivePage, file);
// if (editor != null) {//If it opened an external editor skip it (Vista issue)
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
// assertEquals(editor.getSite().getId(),
// "org.eclipse.ui.DefaultTextEditor");
//
// // open another editor to take the focus away from the first editor
// IDE
// .openEditor(fActivePage, FileUtil.createFile("test.mock2",
// proj));
//
// /*
// * javadoc: If this page already has an editor open on the target
// * object that editor is activated
// */
// // open the editor second time.
// assertEquals(editor, IDE.openEditor(fActivePage, file));
// assertEquals(editor, fActivePage.getActiveEditor());
// }
// }
//
// /**
// * openEditor(IWorkbenchPage page, IFile input, String editorID)
// */
// public void testOpenEditor2() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// final IFile file = FileUtil.createFile("asfasdasdf", proj);
// final String id = MockEditorPart.ID1;
//
// /*
// * javadoc: The editor type is determined by mapping editorId to an
// * editor extension registered with the workbench.
// */
// IEditorPart editor = IDE.openEditor(fActivePage, file, id);
// assertEquals(editor.getSite().getId(), id);
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
//
// // open another editor to take the focus away from the first editor
// IDE.openEditor(fActivePage, FileUtil.createFile("test.mock2", proj));
//
// /*
// * javadoc: If this page already has an editor open on the target object
// * that editor is activated
// */
// // open the first editor second time.
// assertEquals(IDE.openEditor(fActivePage, file, id), editor);
// assertEquals(fActivePage.getActiveEditor(), editor);
// }
//
// /**
// * openEditor(IEditorInput input,String editorId)
// */
// public void testOpenEditor3() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// final String id = MockEditorPart.ID1;
// IEditorInput input = new FileEditorInput(FileUtil.createFile(
// "test.mock1", proj));
//
// /*
// * javadoc: The editor type is determined by mapping editorId to an
// * editor extension registered with the workbench
// */
// IEditorPart editor = IDE.openEditor(fActivePage, input, id);
// assertEquals(editor.getEditorInput(), input);
// assertEquals(editor.getSite().getId(), id);
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
//
// // open another editor to take the focus away from the first editor
// IDE.openEditor(fActivePage, FileUtil.createFile("test.mock2", proj));
//
// /*
// * javadoc: If this page already has an editor open on the target object
// * that editor is activated
// */
// // open the first editor second time.
// assertEquals(IDE.openEditor(fActivePage, input, id), editor);
// assertEquals(fActivePage.getActiveEditor(), editor);
// }
//
// /**
// * openEditor(IMarker marker)
// */
// public void testOpenEditor5() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// IMarker marker = FileUtil.createFile("aa.mock2", proj).createMarker(
// IMarker.TASK);
// CallHistory callTrace;
//
// /*
// * javadoc: the cursor and selection state of the editor is then updated
// * from information recorded in the marker.
// */
// // open the registered editor for the marker resource
// IEditorPart editor = IDE.openEditor(fActivePage, marker);
// callTrace = ((MockEditorPart) editor).getCallHistory();
// assertEquals(editor.getSite().getId(), MockEditorPart.ID2);
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
// assertEquals(callTrace.contains("gotoMarker"), true);
// fActivePage.closeEditor(editor, false);
//
// /*
// * javadoc: If the marker contains an EDITOR_ID_ATTR attribute the
// * attribute value will be used to determine the editor type to be
// * opened
// */
// marker.setAttribute(IDE.EDITOR_ID_ATTR, MockEditorPart.ID1);
// editor = IDE.openEditor(fActivePage, marker);
// callTrace = ((MockEditorPart) editor).getCallHistory();
// assertEquals(editor.getSite().getId(), MockEditorPart.ID1);
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
// assertEquals(callTrace.contains("gotoMarker"), true);
// // do not close the editor this time
//
// /*
// * javdoc: If this page already has an editor open on the target object
// * that editor is activated
// */
// callTrace.clear();
// assertEquals(IDE.openEditor(fActivePage, marker), editor);
// assertEquals(fActivePage.getActiveEditor(), editor);
// assertEquals(callTrace.contains("gotoMarker"), true);
// fActivePage.closeEditor(editor, false);
// }
//
// /**
// * openEditor(IMarker marker, boolean activate)
// */
// public void testOpenEditor6() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// IMarker marker = FileUtil.createFile("aa.mock2", proj).createMarker(
// IMarker.TASK);
// MockPartListener listener = new MockPartListener();
// fActivePage.addPartListener(listener);
// CallHistory listenerCall = listener.getCallHistory();
// CallHistory editorCall;
//
// // we need another editor so that the editor under test can receive
// // events.
// // otherwise, events will be ignored.
// IEditorPart extra = IDE.openEditor(fActivePage, FileUtil.createFile(
// "aaaaa", proj));
//
// /*
// * javadoc: If activate == true the editor will be activated
// */
// // open the registered editor for the marker resource with activation
// IEditorPart editor = IDE.openEditor(fActivePage, marker, true);
// editorCall = ((MockEditorPart) editor).getCallHistory();
// assertEquals(editor.getSite().getId(), MockEditorPart.ID2);
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
//
// /*
// * javadoc: the cursor and selection state of the editor is then updated
// * from information recorded in the marker.
// */
// assertEquals(editorCall.contains("gotoMarker"), true);
// fActivePage.closeEditor(editor, false);
//
// fActivePage.activate(extra);
//
// // open the registered editor for the marker resource without activation
// fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
// IWorkbenchPage.VIEW_ACTIVATE);
// listenerCall.clear();
// editor = IDE.openEditor(fActivePage, marker, false);
// editorCall = ((MockEditorPart) editor).getCallHistory();
// assertEquals(editor.getSite().getId(), MockEditorPart.ID2);
// assertEquals(hasEditor(editor), true);
// assertEquals(listenerCall.contains("partBroughtToTop"), true);
// assertEquals(listenerCall.contains("partActivated"), false);
// assertEquals(editorCall.contains("gotoMarker"), true);
// fActivePage.closeEditor(editor, false);
//
// /*
// * javadoc: If the marker contains an EDITOR_ID_ATTR attribute the
// * attribute value will be used to determine the editor type to be
// * opened
// */
// String id = MockEditorPart.ID1;
// marker.setAttribute(IDE.EDITOR_ID_ATTR, id);
//
// // open an editor with activation
// listenerCall.clear();
//
// editor = IDE.openEditor(fActivePage, marker, true);
// editorCall = ((MockEditorPart) editor).getCallHistory();
// assertEquals(editor.getSite().getId(), id);
// assertEquals(hasEditor(editor), true);
// assertEquals(fActivePage.getActiveEditor(), editor);
// assertEquals(editorCall.contains("gotoMarker"), true);
// fActivePage.closeEditor(editor, false);
//
// fActivePage.activate(extra);
//
// // open an editor without activation
// fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
// IWorkbenchPage.VIEW_ACTIVATE);
// listenerCall.clear();
// editor = IDE.openEditor(fActivePage, marker, false);
// editorCall = ((MockEditorPart) editor).getCallHistory();
// assertEquals(editor.getSite().getId(), id);
// assertEquals(hasEditor(editor), true);
// assertEquals(editorCall.contains("gotoMarker"), true);
// assertEquals(listenerCall.contains("partActivated"), false);
// assertEquals(listenerCall.contains("partBroughtToTop"), true);
// // do not close the editor this time
//
// fActivePage.activate(extra);
// /*
// * javadoc: If this page already has an editor open on the target object
// * that editor is brought to front Note: we need to make a non-editor
// * active first or bringing the editor to front would activate it
// */
// // open the editor second time without activation
// fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
// IWorkbenchPage.VIEW_ACTIVATE);
// listenerCall.clear();
// assertEquals(IDE.openEditor(fActivePage, marker, false), editor);
// assertEquals(listenerCall.contains("partBroughtToTop"), true);
// assertEquals(listenerCall.contains("partActivated"), false);
//
// fActivePage.activate(extra);
//
// /*
// * javdoc: If activate == true the editor will be activated
// */
// // open the editor second time with activation
// listenerCall.clear();
// assertEquals(IDE.openEditor(fActivePage, marker, true), editor);
// assertEquals(editorCall.contains("gotoMarker"), true);
// assertEquals(listenerCall.contains("partBroughtToTop"), true);
// assertEquals(listenerCall.contains("partActivated"), true);
//
// /*
// * javadoc: If activate == false but another editor in the same stack
// * was active, the new editor will be activated regardless.
// */
// // Close the old editor
// fActivePage.closeEditor(editor, false);
// // Ensure another editor in the stack is active
// fActivePage.activate(extra);
// listenerCall.clear();
// // Verify that the editor is still activated
// IDE.openEditor(fActivePage, marker, false);
// assertEquals(listenerCall.contains("partBroughtToTop"), true);
// assertEquals(listenerCall.contains("partActivated"), true);
// }
//
// /**
// * Tests that the marker's value for the <code>IDE.EDITOR_ID_ATTR</code>
// * attribute.
// */
// public void testOpenEditor7_Bug203640() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// IFile file = FileUtil.createFile("aa.mock2", proj);
// IMarker marker = file.createMarker(
// IMarker.TASK);
// marker.setAttribute(IDE.EDITOR_ID_ATTR, MockEditorPart.ID1);
//
// // open a regular text editor
// IEditorPart regularEditor = fActivePage.openEditor(new FileEditorInput(file), EditorsUI.DEFAULT_TEXT_EDITOR_ID);
// assertNotNull(regularEditor);
// assertTrue(regularEditor instanceof TextEditor);
//
// // open the registered editor for the marker resource
// IEditorPart markerEditor = IDE.openEditor(fActivePage, marker);
// assertNotNull(markerEditor);
// assertTrue(markerEditor instanceof MockEditorPart);
//
// // these shouldn't be the same, if they are it's a bug
// assertFalse(markerEditor == regularEditor);
// assertFalse(markerEditor.equals(regularEditor));
// assertEquals(2, fActivePage.getEditorReferences().length);
// }
//
// public void testGetPerspective() throws Throwable {
// assertNotNull(fActivePage.getPerspective());
//
// IWorkbenchPage page = fWin.openPage(EmptyPerspective.PERSP_ID,
// getPageInput());
// assertEquals(EmptyPerspective.PERSP_ID, page.getPerspective().getId());
// }
//
// public void testSetPerspective() throws Throwable {
// IPerspectiveDescriptor per = PlatformUI.getWorkbench()
// .getPerspectiveRegistry().findPerspectiveWithId(
// EmptyPerspective.PERSP_ID);
// fActivePage.setPerspective(per);
// assertEquals(per, fActivePage.getPerspective());
// }
//
// public void testGetLabel() {
// assertNotNull(fActivePage.getLabel());
// }
//
// public void testGetInput() throws Throwable {
// IAdaptable input = getPageInput();
// IWorkbenchPage page = fWin.openPage(input);
// assertEquals(input, page.getInput());
// }
//
// public void testActivate() throws Throwable {
// MockViewPart part = (MockViewPart) fActivePage
// .showView(MockViewPart.ID);
// MockViewPart part2 = (MockViewPart) fActivePage
// .showView(MockViewPart.ID2);
//
// MockPartListener listener = new MockPartListener();
// fActivePage.addPartListener(listener);
// fActivePage.activate(part);
//
// CallHistory callTrace;
//
// callTrace = part2.getCallHistory();
// callTrace.clear();
// fActivePage.activate(part2);
// assertTrue(callTrace.contains("setFocus"));
// assertTrue(listener.getCallHistory().contains("partActivated"));
//
// callTrace = part.getCallHistory();
// callTrace.clear();
// fActivePage.activate(part);
// assertTrue(callTrace.contains("setFocus"));
// assertTrue(listener.getCallHistory().contains("partActivated"));
// }
//
// public void testBringToTop() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// IEditorPart part = IDE.openEditor(fActivePage, FileUtil.createFile(
// "a.mock1", proj));
// IEditorPart part2 = IDE.openEditor(fActivePage, FileUtil.createFile(
// "b.mock1", proj));
//
// MockPartListener listener = new MockPartListener();
// fActivePage.addPartListener(listener);
// CallHistory callTrace = listener.getCallHistory();
//
// // at this point, part2 is active
// fActivePage.bringToTop(part);
// assertEquals(callTrace.contains("partBroughtToTop"), true);
//
// callTrace.clear();
// fActivePage.bringToTop(part2);
// assertEquals(callTrace.contains("partBroughtToTop"), true);
// }
//
// /**
// * Test to ensure that a minimized view can be brought to the top and
// * consequently made visible.
// *
// * @param hasEditors whether there should be editors open or not
// */
// private void testBringToTop_MinimizedViewBug292966(boolean hasEditors) throws Throwable {
// // first show the view we're going to test
// IViewPart propertiesView = fActivePage.showView(IPageLayout.ID_PROP_SHEET);
// assertNotNull(propertiesView);
//
// proj = FileUtil.createProject("testOpenEditor");
// // open an editor
// IEditorPart editor = IDE.openEditor(fActivePage, FileUtil.createFile(
// "a.mock1", proj));
// assertNotNull("The editor could not be opened", editor); //$NON-NLS-1$
// assertTrue("The editor is not visible", fActivePage.isPartVisible(editor)); //$NON-NLS-1$
//
// if (!hasEditors) {
// // close editors if we don't want them opened for this test
// fActivePage.closeAllEditors(false);
// assertEquals("All the editors should have been closed", 0, fActivePage.getEditorReferences().length); //$NON-NLS-1$
// }
//
// // minimize the view we're testing
// fActivePage.setPartState(fActivePage.getReference(propertiesView), IWorkbenchPage.STATE_MINIMIZED);
// assertFalse("A minimized view should not be visible", fActivePage.isPartVisible(propertiesView)); //$NON-NLS-1$
//
// // open another view so that it now becomes the active part container
// IViewPart projectExplorer = fActivePage.showView(IPageLayout.ID_PROJECT_EXPLORER);
// // get the list of views that shares the stack with this other view
// IViewPart[] viewStack = fActivePage.getViewStack(projectExplorer);
// // make sure that we didn't inadvertently bring back the test view by mistake
// for (int i = 0; i < viewStack.length; i++) {
// assertFalse("The properties view should not be on the same stack as the project explorer", //$NON-NLS-1$
// viewStack[i].getSite().getId().equals(IPageLayout.ID_PROP_SHEET));
// }
//
// // bring the test view back from its minimized state
// fActivePage.bringToTop(propertiesView);
// // the view should be visible
// assertTrue("Invoking bringToTop(IWorkbenchPart) should cause the part to be visible", //$NON-NLS-1$
// fActivePage.isPartVisible(propertiesView));
// }
//
// public void testBringToTop_MinimizedViewWithEditorsBug292966() throws Throwable {
// testBringToTop_MinimizedViewBug292966(false);
// }
//
// public void testBringToTop_MinimizedViewWithoutEditorsBug292966() throws Throwable {
// testBringToTop_MinimizedViewBug292966(true);
// }
//
// public void testGetWorkbenchWindow() {
// /*
// * Commented out because until test case can be updated to work with new
// * window/page/perspective implementation
// *
// * assertEquals(fActivePage.getWorkbenchWindow(), fWin); IWorkbenchPage
// * page = openTestPage(fWin); assertEquals(page.getWorkbenchWindow(),
// * fWin);
// */
// }
//
// public void testShowView() throws Throwable {
// /*
// * javadoc: Shows a view in this page and give it focus
// */
// MockViewPart view = (MockViewPart) fActivePage
// .showView(MockViewPart.ID);
// assertNotNull(view);
// assertTrue(view.getCallHistory().verifyOrder(
// new String[] { "init", "createPartControl", "setFocus" }));
//
// fActivePage.showView(MockViewPart.ID2);
//
// /*
// * javadoc: If the view is already visible, it is given focus
// */
// CallHistory callTrace = view.getCallHistory();
// callTrace.clear();
// assertEquals(fActivePage.showView(MockViewPart.ID), view);
// assertEquals(callTrace.contains("setFocus"), true);
// }
//
// /**
// * Tests showing multi-instance views (docked normally).
// */
// public void testShowViewMult() throws Throwable {
// /*
// * javadoc: Shows the view identified by the given view id and secondary
// * id in this page and gives it focus. This allows multiple instances of
// * a particular view to be created. They are disambiguated using the
// * secondary id.
// */
// MockViewPart view = (MockViewPart) fActivePage
// .showView(MockViewPart.IDMULT);
// assertNotNull(view);
// assertTrue(view.getCallHistory().verifyOrder(
// new String[] { "init", "createPartControl", "setFocus" }));
// MockViewPart view2 = (MockViewPart) fActivePage.showView(
// MockViewPart.IDMULT, "2", IWorkbenchPage.VIEW_ACTIVATE);
// assertNotNull(view2);
// assertTrue(view2.getCallHistory().verifyOrder(
// new String[] { "init", "createPartControl", "setFocus" }));
// assertTrue(!view.equals(view2));
// MockViewPart view3 = (MockViewPart) fActivePage.showView(
// MockViewPart.IDMULT, "3", IWorkbenchPage.VIEW_ACTIVATE);
// assertNotNull(view3);
// assertTrue(view3.getCallHistory().verifyOrder(
// new String[] { "init", "createPartControl", "setFocus" }));
// assertTrue(!view.equals(view3));
// assertTrue(!view2.equals(view3));
//
// /*
// * javadoc: If there is a view identified by the given view id and
// * secondary id already open in this page, it is given focus.
// */
// CallHistory callTrace = view.getCallHistory();
// callTrace.clear();
// assertEquals(fActivePage.showView(MockViewPart.IDMULT), view);
// assertEquals(callTrace.contains("setFocus"), true);
// CallHistory callTrace2 = view2.getCallHistory();
// callTrace.clear();
// callTrace2.clear();
// assertEquals(fActivePage.showView(MockViewPart.IDMULT, "2",
// IWorkbenchPage.VIEW_ACTIVATE), view2);
// assertEquals(callTrace2.contains("setFocus"), true);
// assertEquals(callTrace.contains("setFocus"), false);
// CallHistory callTrace3 = view3.getCallHistory();
// callTrace.clear();
// callTrace2.clear();
// callTrace3.clear();
// assertEquals(fActivePage.showView(MockViewPart.IDMULT, "3",
// IWorkbenchPage.VIEW_ACTIVATE), view3);
// assertEquals(callTrace3.contains("setFocus"), true);
// assertEquals(callTrace.contains("setFocus"), false);
// assertEquals(callTrace2.contains("setFocus"), false);
//
// /*
// * javadoc: If a secondary id is given, the view must allow multiple
// * instances by having specified allowMultiple="true" in its extension.
// */
// boolean exceptionThrown = false;
// try {
// fActivePage.showView(MockViewPart.ID, "2",
// IWorkbenchPage.VIEW_ACTIVATE);
// } catch (PartInitException e) {
// assertEquals(e.getMessage().indexOf("mult") != -1, true);
// exceptionThrown = true;
// }
// assertEquals(exceptionThrown, true);
// }
//
// /**
// * Tests showing multi-instance views (as fast views). This is a regression
// * test for bug 76669 - [Perspectives] NullPointerException in
// * Perspective.getFastViewWidthRatio()
// */
// public void testShowViewMultFast() throws Throwable {
// /*
// * javadoc: Shows the view identified by the given view id and secondary
// * id in this page and gives it focus. This allows multiple instances of
// * a particular view to be created. They are disambiguated using the
// * secondary id.
// */
// MockViewPart view = (MockViewPart) fActivePage
// .showView(MockViewPart.IDMULT);
// assertNotNull(view);
// assertTrue(view.getCallHistory().verifyOrder(
// new String[] { "init", "createPartControl", "setFocus" }));
// MockViewPart view2 = (MockViewPart) fActivePage.showView(
// MockViewPart.IDMULT, "2", IWorkbenchPage.VIEW_ACTIVATE);
// assertNotNull(view2);
// assertTrue(view2.getCallHistory().verifyOrder(
// new String[] { "init", "createPartControl", "setFocus" }));
// assertTrue(!view.equals(view2));
//
// IViewReference ref = (IViewReference) fActivePage.getReference(view);
// IViewReference ref2 = (IViewReference) fActivePage.getReference(view2);
// facade.addFastView(fActivePage, ref);
// facade.addFastView(fActivePage, ref2);
//
// fActivePage.activate(view);
// assertEquals(view, fActivePage.getActivePart());
//
// fActivePage.activate(view2);
// assertEquals(view2, fActivePage.getActivePart());
// }
//
// /**
// * Tests saving the page state when there is a fast view that is also a
// * multi-instance view. This is a regression test for bug 76669 -
// * [Perspectives] NullPointerException in
// * Perspective.getFastViewWidthRatio()
// */
// public void testBug76669() throws Throwable {
// MockViewPart view = (MockViewPart) fActivePage
// .showView(MockViewPart.IDMULT);
// MockViewPart view2 = (MockViewPart) fActivePage.showView(
// MockViewPart.IDMULT, "2", IWorkbenchPage.VIEW_ACTIVATE);
//
// IViewReference ref = (IViewReference) fActivePage.getReference(view);
// IViewReference ref2 = (IViewReference) fActivePage.getReference(view2);
// facade.addFastView(fActivePage, ref);
// facade.addFastView(fActivePage, ref2);
//
// IMemento memento = XMLMemento.createWriteRoot("page");
// facade.saveState(fActivePage, memento);
// IMemento persps = memento.getChild("perspectives");
// IMemento persp = persps.getChildren("perspective")[0];
// IMemento[] fastViews = persp.getChild("fastViews").getChildren("view");
// assertEquals(2, fastViews.length);
// }
//
// public void testFindView() throws Throwable {
// String id = MockViewPart.ID3;
// // id of valid, but not open view
// assertNull(fActivePage.findView(id));
//
// IViewPart view = fActivePage.showView(id);
// assertEquals(fActivePage.findView(id), view);
//
// // close view
// fActivePage.hideView(view);
// assertNull(fActivePage.findView(id));
// }
//
// public void testFindViewReference() throws Throwable {
// fActivePage.getWorkbenchWindow().getWorkbench().showPerspective(
// SessionPerspective.ID, fActivePage.getWorkbenchWindow());
// assertNull(fActivePage.findViewReference(MockViewPart.ID4));
//
// fActivePage.showView(MockViewPart.ID4);
// assertNotNull(fActivePage.findViewReference(MockViewPart.ID4));
// }
//
// public void testGetViews() throws Throwable {
// int totalBefore = fActivePage.getViewReferences().length;
//
// IViewPart view = fActivePage.showView(MockViewPart.ID2);
// assertEquals(hasView(view), true);
// assertEquals(fActivePage.getViewReferences().length, totalBefore + 1);
//
// fActivePage.hideView(view);
// assertEquals(hasView(view), false);
// assertEquals(fActivePage.getViewReferences().length, totalBefore);
// }
//
// public void testHideViewWithPart() throws Throwable {
// // test that nothing bad happens with a null parameter
// try {
// fActivePage.hideView((IViewPart) null);
// } catch (RuntimeException e) {
// fail(e.getMessage());
// }
//
// IViewPart view = fActivePage.showView(MockViewPart.ID3);
//
// fActivePage.hideView(view);
// CallHistory callTrace = ((MockViewPart) view).getCallHistory();
// assertTrue(callTrace.contains("dispose"));
// }
//
// public void testHideViewWithReference() throws Throwable {
// // test that nothing bad happens with a null parameter
// try {
// fActivePage.hideView((IViewReference) null);
// } catch (RuntimeException e) {
// fail(e.getMessage());
// }
//
// IViewPart view = fActivePage.showView(MockViewPart.ID4);
// IViewReference ref = fActivePage.findViewReference(MockViewPart.ID4);
// fActivePage.hideView(ref);
// CallHistory callTrace = ((MockViewPart) view).getCallHistory();
// assertTrue(callTrace.contains("dispose"));
//
// }
//
// public void testHideSaveableView() throws Throwable {
// String viewId = SaveableMockViewPart.ID;
// SaveableMockViewPart view = (SaveableMockViewPart) fActivePage
// .showView(viewId);
// fActivePage.hideView(view);
// CallHistory callTrace = view.getCallHistory();
// assertTrue(callTrace.contains("isDirty"));
// assertTrue(callTrace.contains("dispose"));
// assertEquals(fActivePage.findView(viewId), null);
//
// try {
// facade.saveableHelperSetAutomatedResponse(1); // No
// view = (SaveableMockViewPart) fActivePage.showView(viewId);
// view.setDirty(true);
// fActivePage.hideView(view);
// callTrace = view.getCallHistory();
// assertTrue(callTrace.contains("isDirty"));
// assertFalse(callTrace.contains("doSave"));
// assertTrue(callTrace.contains("dispose"));
// assertEquals(fActivePage.findView(viewId), null);
//
// facade.saveableHelperSetAutomatedResponse(2); // Cancel
// view = (SaveableMockViewPart) fActivePage.showView(viewId);
// view.setDirty(true);
// fActivePage.hideView(view);
// callTrace = view.getCallHistory();
// assertTrue(callTrace.contains("isDirty"));
// assertFalse(callTrace.contains("doSave"));
// assertFalse(callTrace.contains("dispose"));
// assertEquals(fActivePage.findView(viewId), view);
//
// facade.saveableHelperSetAutomatedResponse(0); // Yes
// view = (SaveableMockViewPart) fActivePage.showView(viewId);
// view.setDirty(true);
// fActivePage.hideView(view);
// callTrace = view.getCallHistory();
// assertTrue(callTrace.contains("isDirty"));
// assertTrue(callTrace.contains("doSave"));
// assertTrue(callTrace.contains("dispose"));
// assertEquals(fActivePage.findView(viewId), null);
//
// // don't leave the view showing, or the UI will block on window
// // close
// } finally {
// facade.saveableHelperSetAutomatedResponse(-1); // restore default
// // (prompt)
// }
// }
//
// /**
// * Tests that a close will fall back to the default if the view returns
// * ISaveable2.DEFAULT.
// *
// * @throws Throwable
// */
// public void testCloseWithSaveNeeded() throws Throwable {
// String viewId = UserSaveableMockViewPart.ID;
// UserSaveableMockViewPart view = (UserSaveableMockViewPart) fActivePage
// .showView(viewId);
// fActivePage.hideView(view);
//
// UserSaveableMockViewPart view2 = null;
//
// CallHistory callTrace = view.getCallHistory();
// assertTrue(callTrace.contains("isDirty"));
// assertTrue(callTrace.contains("dispose"));
// assertEquals(fActivePage.findView(UserSaveableMockViewPart.ID), null);
//
// try {
// facade.saveableHelperSetAutomatedResponse(3); // DEFAULT
// view = (UserSaveableMockViewPart) fActivePage.showView(viewId);
// view.setDirty(true);
// view2 = (UserSaveableMockViewPart) fActivePage.showView(viewId,
// "2", IWorkbenchPage.VIEW_ACTIVATE);
// assertNotNull(view2);
// view2.setDirty(true);
//
// fActivePage.saveAllEditors(true);
//
// assertFalse(view.isDirty());
// assertFalse(view2.isDirty());
//
// callTrace = view.getCallHistory();
// fActivePage.hideView(view);
// fActivePage.hideView(view2);
//
// assertTrue(callTrace.contains("isDirty"));
// assertTrue(callTrace.contains("doSave"));
// assertEquals(fActivePage.findView(viewId), null);
//
// // don't leave the view showing, or the UI will block on window
// // close
// } finally {
// facade
// .saveableHelperSetAutomatedResponse(-1); // restore
// // default
// // (prompt)
// }
// }
//
// /**
// * Tests that a close will fall back to the default if the view returns
// * ISaveable2.DEFAULT.
// *
// * @throws Throwable
// */
// public void testSaveEffectsSharedModel() throws Throwable {
// String viewId = UserSaveableSharedViewPart.ID;
// UserSaveableSharedViewPart view = null;
//
// UserSaveableSharedViewPart view2 = null;
//
// assertEquals(fActivePage.findView(UserSaveableSharedViewPart.ID), null);
//
// try {
// facade.saveableHelperSetAutomatedResponse(3); // DEFAULT
// UserSaveableSharedViewPart.SharedModel model = new UserSaveableSharedViewPart.SharedModel();
// view = (UserSaveableSharedViewPart) fActivePage.showView(viewId);
// view.setSharedModel(model);
//
// view2 = (UserSaveableSharedViewPart) fActivePage.showView(viewId,
// "2", IWorkbenchPage.VIEW_ACTIVATE);
// assertNotNull(view2);
// view2.setSharedModel(model);
//
// fActivePage.saveAllEditors(true);
//
// assertFalse(view.isDirty());
// assertFalse(view2.isDirty());
//
// CallHistory callTrace = view.getCallHistory();
// CallHistory call2 = view2.getCallHistory();
//
// assertTrue(callTrace.contains("isDirty"));
// assertTrue(call2.contains("isDirty"));
// assertTrue("At least one should call doSave", callTrace
// .contains("doSave")
// || call2.contains("doSave"));
// assertFalse("Both should not call doSave", callTrace
// .contains("doSave")
// && call2.contains("doSave"));
//
// // don't leave the view showing, or the UI will block on window
// // close
// } finally {
// facade
// .saveableHelperSetAutomatedResponse(-1); // restore
// // default
// // (prompt)
// fActivePage.hideView(view);
// fActivePage.hideView(view2);
// }
// }
//
// public void testClose() throws Throwable {
// IWorkbenchPage page = openTestPage(fWin);
//
// proj = FileUtil.createProject("testOpenEditor");
// final IFile file = FileUtil.createFile("aaa.mock1", proj);
// IEditorPart editor = IDE.openEditor(page, file);
// CallHistory callTrace = ((MockEditorPart) editor).getCallHistory();
// callTrace.clear();
//
// /*
// * javadoc: If the page has open editors with unsaved content and save
// * is true, the user will be given the opportunity to save them
// */
// assertEquals(page.close(), true);
// assertEquals(callTrace
// .verifyOrder(new String[] { "isDirty", "dispose" }), true);
// assertEquals(fWin.getActivePage(), fActivePage);
// }
//
// public void testCloseEditor() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// final IFile file = FileUtil.createFile("test.mock1", proj);
// IEditorPart editor;
// CallHistory callTrace;
// MockEditorPart mock;
//
// /*
// * javadoc: Parameters: save - true to save the editor contents if
// * required (recommended)
// */
// // create a clean editor that needs to be saved on closing
// editor = IDE.openEditor(fActivePage, file);
// mock = (MockEditorPart) editor;
// mock.setSaveNeeded(true);
// callTrace = mock.getCallHistory();
// callTrace.clear();
// // close the editor with save confirmation
// assertEquals(fActivePage.closeEditor(editor, true), true);
// assertEquals(callTrace
// .verifyOrder(new String[] { "isDirty", "dispose" }), true);
//
// /*
// * javadoc: If the editor has unsaved content and save is true, the user
// * will be given the opportunity to save it.
// */
// // can't be tested
// /*
// * javadoc: Parameters: save - false to discard any unsaved changes
// */
// // create a dirty editor
// editor = IDE.openEditor(fActivePage, file);
// mock = (MockEditorPart) editor;
// mock.setDirty(true);
// mock.setSaveNeeded(true);
// callTrace = mock.getCallHistory();
// callTrace.clear();
// // close the editor and discard changes
// assertEquals(fActivePage.closeEditor(editor, false), true);
// assertEquals(callTrace.contains("isSaveOnCloseNeeded"), false);
// /*
// * It is possible that some action may query the isDirty value of the
// * editor to update its enabled state. There is nothing wrong in doing
// * that, so do not test for no isDirty call here.
// *
// * assertEquals(callTrace.contains( "isDirty"), false);
// */
// assertEquals(callTrace.contains("doSave"), false);
// assertEquals(callTrace.contains("dispose"), true);
// }
//
// public void testCloseEditors() throws Throwable {
// int total = 5;
// final IFile[] files = new IFile[total];
// IEditorPart[] editors = new IEditorPart[total];
// IEditorReference[] editorRefs = new IEditorReference[total];
// CallHistory[] callTraces = new CallHistory[total];
// MockEditorPart[] mocks = new MockEditorPart[total];
//
// proj = FileUtil.createProject("testCloseEditors");
// for (int i = 0; i < total; i++)
// files[i] = FileUtil.createFile(i + ".mock2", proj);
//
// /*
// * javadoc: If the page has open editors with unsaved content and save
// * is true, the user will be given the opportunity to save them.
// */
// // close all clean editors with confirmation
// for (int i = 0; i < total; i++) {
// editors[i] = IDE.openEditor(fActivePage, files[i]);
// callTraces[i] = ((MockEditorPart) editors[i]).getCallHistory();
// }
//
// editorRefs = fActivePage.getEditorReferences();
// assertEquals(fActivePage.closeEditors(editorRefs, true), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), false);
// callTraces[i].clear();
// }
//
// // close all dirty editors with confirmation
// // can't be tested
//
// // close all dirty editors discarding them
// for (int i = 0; i < total; i++) {
// editors[i] = IDE.openEditor(fActivePage, files[i]);
// mocks[i] = (MockEditorPart) editors[i];
// mocks[i].setDirty(true);
// callTraces[i] = mocks[i].getCallHistory();
// }
// editorRefs = fActivePage.getEditorReferences();
// assertEquals(fActivePage.closeEditors(editorRefs, false), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("doSave"), false);
// }
//
// // close empty array of editors
// total = 1;
// for (int i = 0; i < total; i++) {
// editors[i] = IDE.openEditor(fActivePage, files[i]);
// mocks[i] = (MockEditorPart) editors[i];
// mocks[i].setDirty(true);
// callTraces[i] = mocks[i].getCallHistory();
// }
// // empty array test
// editorRefs = new IEditorReference[0];
// assertEquals(fActivePage.closeEditors(editorRefs, true), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), false);
// callTraces[i].clear();
// }
//
// // close the last remaining editor, with save=false
// editorRefs = fActivePage.getEditorReferences();
// fActivePage.closeEditors(editorRefs, false);
// }
//
// public void testCloseAllEditors() throws Throwable {
// int total = 5;
// final IFile[] files = new IFile[total];
// IEditorPart[] editors = new IEditorPart[total];
// CallHistory[] callTraces = new CallHistory[total];
// MockEditorPart[] mocks = new MockEditorPart[total];
//
// proj = FileUtil.createProject("testOpenEditor");
// for (int i = 0; i < total; i++)
// files[i] = FileUtil.createFile(i + ".mock2", proj);
//
// /*
// * javadoc: If the page has open editors with unsaved content and save
// * is true, the user will be given the opportunity to save them.
// */
// // close all clean editors with confirmation
// for (int i = 0; i < total; i++) {
// editors[i] = IDE.openEditor(fActivePage, files[i]);
// callTraces[i] = ((MockEditorPart) editors[i]).getCallHistory();
// }
// assertEquals(fActivePage.closeAllEditors(true), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), false);
// callTraces[i].clear();
// }
//
// // close all dirty editors with confirmation
// // can't be tested
//
// // close all dirty editors discarding them
// for (int i = 0; i < total; i++) {
// editors[i] = IDE.openEditor(fActivePage, files[i]);
// mocks[i] = (MockEditorPart) editors[i];
// mocks[i].setDirty(true);
// callTraces[i] = mocks[i].getCallHistory();
// }
// assertEquals(fActivePage.closeAllEditors(false), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("doSave"), false);
// }
// }
//
// public void testSaveEditor() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// final IFile file = FileUtil.createFile("test.mock1", proj);
// IEditorPart editor;
// CallHistory callTrace;
// MockEditorPart mock;
//
// // create a clean editor
// editor = IDE.openEditor(fActivePage, file);
// mock = (MockEditorPart) editor;
// callTrace = mock.getCallHistory();
// callTrace.clear();
//
// /*
// * javadoc: Saves the contents of the given editor if dirty. If not,
// * this method returns without effect
// */
// // save the clean editor with confirmation
// assertEquals(fActivePage.saveEditor(editor, true), true);
// assertEquals(callTrace.contains("isDirty"), true);
// assertEquals(callTrace.contains("doSave"), false);
//
// /*
// * javadoc: If confirm is true the user is prompted to confirm the
// * command.
// */
// // can't be tested
// /*
// * javadoc: Otherwise, the save happens without prompt.
// */
// // save the clean editor without confirmation
// assertEquals(fActivePage.saveEditor(editor, false), true);
// assertEquals(callTrace.contains("isDirty"), true);
// assertEquals(callTrace.contains("doSave"), false);
//
// // save the dirty editor without confirmation
// mock.setDirty(true);
// callTrace.clear();
// assertEquals(fActivePage.saveEditor(editor, false), true);
// assertEquals(callTrace
// .verifyOrder(new String[] { "isDirty", "doSave" }), true);
// }
//
// public void testIDESaveAllEditors() throws Throwable {
// int total = 3;
//
// final IFile[] files = new IFile[total];
// IEditorPart[] editors = new IEditorPart[total];
// CallHistory[] callTraces = new CallHistory[total];
// MockEditorPart[] mocks = new MockEditorPart[total];
//
// proj = FileUtil.createProject("testOpenEditor");
// for (int i = 0; i < total; i++) {
// files[i] = FileUtil.createFile(i + ".mock2", proj);
// editors[i] = IDE.openEditor(fActivePage, files[i]);
// mocks[i] = (MockEditorPart) editors[i];
// callTraces[i] = mocks[i].getCallHistory();
// }
//
// /*
// * javadoc: If there are no dirty editors this method returns without
// * effect. javadoc: If confirm is true the user is prompted to confirm
// * the command
// */
// // save all clean editors with confirmation
// assertEquals(IDE.saveAllEditors(new IResource[] { proj }, true), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), false);
// callTraces[i].clear();
// }
//
// // save all dirty editors with confirmation can't be tested
//
// /*
// * javadoc: Parameters: confirm - false to save unsaved changes without
// * asking
// */
// // save all clean editors without confirmation
// assertEquals(IDE.saveAllEditors(new IResource[] { proj }, false), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), false);
// callTraces[i].clear();
// }
//
// // save all dirty editors with resource that IS NOT a parent
// // of the contents of the dirty editors without confirmation, this
// // should not
// // save any as they are not parented by the resource provided
// for (int i = 0; i < total; i++)
// mocks[i].setDirty(true);
//
// IResource emptyProj = FileUtil
// .createProject("testOpenEditorEmptyProject");
// assertEquals(IDE.saveAllEditors(new IResource[] { emptyProj }, false),
// true);
// for (int i = 0; i < total; i++) {
// // the editors were not in the empty project hence still dirty
// assertEquals(mocks[i].isDirty(), true);
// callTraces[i].clear();
// }
//
// // save all dirty editors with resource that IS a parent
// // of the contents of the editors without confirmation, this should
// // save them as they are parented by the resource provided
// assertEquals(IDE.saveAllEditors(new IResource[] { proj }, false), true);
// for (int i = 0; i < total; i++) {
// // the editors were not in the empty project hence still dirty
// assertEquals(mocks[i].isDirty(), false);
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), true);
// callTraces[i].clear();
// }
//
// // save all dirty editors with resource that IS NOT a parent
// // of the contents of the dirty editors without confirmation, this
// // should not
// // save any as they are not parented by the resource provided
// for (int i = 0; i < total; i++)
// mocks[i].setDirty(true);
// assertEquals(IDE.saveAllEditors(new IResource[] {}, false), true);
// for (int i = 0; i < total; i++) {
// // the editors were not in the empty project hence still dirty
// assertEquals(mocks[i].isDirty(), true);
// callTraces[i].clear();
// }
//
// // clear the dirty state so the tearDown does not open a confirm dialog.
// for (int i = 0; i < total; i++)
// mocks[i].setDirty(false);
// }
//
// public void testSaveAllEditors() throws Throwable {
// int total = 3;
//
// final IFile[] files = new IFile[total];
// IEditorPart[] editors = new IEditorPart[total];
// CallHistory[] callTraces = new CallHistory[total];
// MockEditorPart[] mocks = new MockEditorPart[total];
//
// proj = FileUtil.createProject("testOpenEditor");
// for (int i = 0; i < total; i++) {
// files[i] = FileUtil.createFile(i + ".mock2", proj);
// editors[i] = IDE.openEditor(fActivePage, files[i]);
// mocks[i] = (MockEditorPart) editors[i];
// callTraces[i] = mocks[i].getCallHistory();
// }
//
// /*
// * javadoc: If there are no dirty editors this method returns without
// * effect. javadoc: If confirm is true the user is prompted to confirm
// * the command
// */
// // save all clean editors with confirmation
// assertEquals(fActivePage.saveAllEditors(true), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), false);
// callTraces[i].clear();
// }
//
// // save all dirty editors with confirmation can't be tested
//
// /*
// * javadoc: Parameters: confirm - false to save unsaved changes without
// * asking
// */
// // save all clean editors without confirmation
// assertEquals(fActivePage.saveAllEditors(false), true);
// for (int i = 0; i < total; i++) {
// assertEquals(callTraces[i].contains("isDirty"), true);
// assertEquals(callTraces[i].contains("doSave"), false);
// callTraces[i].clear();
// }
//
// // save all dirty editors without confirmation
// for (int i = 0; i < total; i++)
// mocks[i].setDirty(true);
// assertEquals(fActivePage.saveAllEditors(false), true);
// for (int i = 0; i < total; i++)
// assertEquals(callTraces[i].verifyOrder(new String[] { "isDirty",
// "doSave" }), true);
// }
//
// public void testGetEditors() throws Throwable {
// proj = FileUtil.createProject("testOpenEditor");
// int totalBefore = fActivePage.getEditorReferences().length;
// int num = 3;
// IEditorPart[] editors = new IEditorPart[num];
//
// for (int i = 0; i < num; i++) {
// editors[i] = IDE.openEditor(fActivePage, FileUtil.createFile(i
// + ".mock2", proj));
// assertEquals(hasEditor(editors[i]), true);
// }
// assertEquals(fActivePage.getEditorReferences().length, totalBefore
// + num);
//
// fActivePage.closeEditor(editors[0], false);
// assertEquals(hasEditor(editors[0]), false);
// assertEquals(fActivePage.getEditorReferences().length, totalBefore
// + num - 1);
//
// fActivePage.closeAllEditors(false);
// assertEquals(fActivePage.getEditorReferences().length, 0);
// }
//
// public void testShowActionSet() {
// String id = MockActionDelegate.ACTION_SET_ID;
//
// int totalBefore = facade.getActionSetCount(fActivePage);
// fActivePage.showActionSet(id);
//
// facade.assertActionSetId(fActivePage, id, true);
//
// // check that the method does not add an invalid action set to itself
// id = IConstants.FakeID;
// fActivePage.showActionSet(id);
//
// facade.assertActionSetId(fActivePage, id, false);
// assertEquals(facade.getActionSetCount(fActivePage), totalBefore + 1);
// }
//
// public void testHideActionSet() {
// int totalBefore = facade.getActionSetCount(fActivePage);
//
// String id = MockWorkbenchWindowActionDelegate.SET_ID;
// fActivePage.showActionSet(id);
// assertEquals(facade.getActionSetCount(fActivePage), totalBefore + 1);
//
// fActivePage.hideActionSet(id);
// assertEquals(facade.getActionSetCount(fActivePage), totalBefore);
//
// facade.assertActionSetId(fActivePage, id, false);
// }
//
// /**
// * Return whether or not the editor exists in the current page.
// *
// * @param editor
// * @return boolean
// */
// private boolean hasEditor(IEditorPart editor) {
// IEditorReference[] references = fActivePage.getEditorReferences();
// for (int i = 0; i < references.length; i++) {
// if (references[i].getEditor(false).equals(editor))
// return true;
// }
// return false;
// }
//
// /**
// * Return whether or not the view exists in the current page.
// *
// * @param editor
// * @return boolean
// */
// private boolean hasView(IViewPart view) {
// IViewReference[] references = fActivePage.getViewReferences();
// for (int i = 0; i < references.length; i++) {
// if (references[i].getView(false).equals(view))
// return true;
// }
// return false;
// }
//
// public void testStackOrder() throws PartInitException {
// IViewPart part1 = fActivePage.showView(MockViewPart.ID);
// IViewPart part2 = fActivePage.showView(MockViewPart.ID2);
// IViewPart part3 = fActivePage.showView(MockViewPart.ID3);
// IViewPart part4 = fActivePage.showView(MockViewPart.ID4);
//
// IViewPart[] stack = fActivePage.getViewStack(part1);
// assertTrue(stack.length == 4);
// assertTrue(stack[0] == part4);
// assertTrue(stack[1] == part3);
// assertTrue(stack[2] == part2);
// assertTrue(stack[3] == part1);
//
// fActivePage.activate(part2);
// stack = fActivePage.getViewStack(part1);
// assertTrue(stack.length == 4);
// assertTrue(stack[0] == part2);
// assertTrue(stack[1] == part4);
// assertTrue(stack[2] == part3);
// assertTrue(stack[3] == part1);
//
// fActivePage.activate(part1);
// stack = fActivePage.getViewStack(part1);
// assertTrue(stack.length == 4);
// assertTrue(stack[0] == part1);
// assertTrue(stack[1] == part2);
// assertTrue(stack[2] == part4);
// assertTrue(stack[3] == part3);
//
// fActivePage.activate(part3);
// stack = fActivePage.getViewStack(part1);
// assertTrue(stack.length == 4);
// assertTrue(stack[0] == part3);
// assertTrue(stack[1] == part1);
// assertTrue(stack[2] == part2);
// assertTrue(stack[3] == part4);
// }
//
// /**
// * Test the VIEW_CREATE parameter for showView. Ensures that the created
// * view is not the active part.
// *
// */
// public void testView_CREATE1() throws PartInitException {
// fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
// .getPerspectiveRegistry().findPerspectiveWithId(
// "org.eclipse.ui.tests.api.ViewPerspective"));
//
// // create a part to be active
// IViewPart activePart = fActivePage.showView(MockViewPart.ID);
// IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
// IWorkbenchPage.VIEW_CREATE);
//
// IViewPart[] stack = fActivePage.getViewStack(activePart);
// assertEquals(2, stack.length);
//
// assertEquals(activePart, stack[0]);
// assertEquals(createdPart, stack[1]);
//
// assertFalse(fActivePage.isPartVisible(createdPart));
//
// assertEquals(activePart, fActivePage.getActivePart());
// }
//
// /**
// * Test the VIEW_CREATE parameter for showView. Ensures that the created
// * view is not the active part and is not visible
// */
// public void testView_CREATE2() throws PartInitException {
// fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
// .getPerspectiveRegistry().findPerspectiveWithId(
// "org.eclipse.ui.tests.api.ViewPerspective"));
//
// // create a part to be active
// IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
// IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
// IWorkbenchPage.VIEW_CREATE);
//
// IViewPart[] stack = fActivePage.getViewStack(createdPart);
// assertEquals(2, stack.length);
//
// assertEquals(fActivePage.findView(MockViewPart.ID), stack[0]);
// assertEquals(createdPart, stack[1]);
//
// assertFalse(fActivePage.isPartVisible(createdPart));
//
// assertEquals(activePart, fActivePage.getActivePart());
// }
//
// /**
// * Test the VIEW_CREATE parameter for showView. Ensures that the created
// * view is not the active part and is visible.
// */
// public void testView_CREATE3() throws PartInitException {
// fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
// .getPerspectiveRegistry().findPerspectiveWithId(
// "org.eclipse.ui.tests.api.ViewPerspective"));
//
// // create a part to be active
// IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
// IViewPart createdPart = fActivePage.showView(MockViewPart.ID4, null,
// IWorkbenchPage.VIEW_CREATE);
//
// IViewPart[] stack = fActivePage.getViewStack(createdPart);
// assertEquals(1, stack.length);
//
// assertEquals(createdPart, stack[0]);
//
// assertTrue(fActivePage.isPartVisible(createdPart));
//
// assertEquals(activePart, fActivePage.getActivePart());
// }
//
// /**
// * Test the VIEW_VISIBLE parameter for showView, opening the view in the
// * stack containing the active view. Ensures that the created view is not
// * the active part and is not visible.
// */
// public void testView_VISIBLE1() throws PartInitException {
// fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
// .getPerspectiveRegistry().findPerspectiveWithId(
// "org.eclipse.ui.tests.api.ViewPerspective"));
//
// // create a part to be active
// IViewPart activePart = fActivePage.showView(MockViewPart.ID);
// IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
// IWorkbenchPage.VIEW_VISIBLE);
// IViewPart[] stack = fActivePage.getViewStack(activePart);
// assertEquals(2, stack.length);
//
// assertEquals(activePart, stack[0]);
// assertEquals(createdPart, stack[1]);
//
// assertFalse(fActivePage.isPartVisible(createdPart));
//
// assertEquals(activePart, fActivePage.getActivePart());
// }
//
// /**
// * Test the VIEW_VISIBLE parameter for showView, opening the view in its own
// * stack. Ensures that the created view is not active part but is the top
// * part in its stack.
// */
// public void testView_VISIBLE3() throws PartInitException {
// fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
// .getPerspectiveRegistry().findPerspectiveWithId(
// "org.eclipse.ui.tests.api.ViewPerspective"));
//
// // create a part to be active
// IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
//
// IViewPart createdPart = fActivePage.showView(MockViewPart.ID4, null,
// IWorkbenchPage.VIEW_VISIBLE);
// IViewPart[] stack = fActivePage.getViewStack(createdPart);
// assertEquals(1, stack.length);
//
// assertEquals(createdPart, stack[0]);
//
// assertTrue(fActivePage.isPartVisible(createdPart));
//
// assertEquals(activePart, fActivePage.getActivePart());
// }
//
// /**
// * Test opening a perspective with a fast view.
// */
// public void testOpenPerspectiveWithFastView() {
//
// try {
// fWin.getWorkbench().showPerspective(
// PerspectiveWithFastView.PERSP_ID, fWin);
// } catch (WorkbenchException e) {
// fail("Unexpected WorkbenchException: " + e);
// }
//
// IViewReference[] fastViews = facade.getFastViews(fActivePage);
// assertEquals(fastViews.length, 1);
// assertEquals(fastViews[0].getId(),
// "org.eclipse.ui.views.ResourceNavigator");
// assertEquals(fActivePage.getViewReferences().length, 1);
// assertTrue(fActivePage.getViewReferences()[0].isFastView());
//
// IPerspectiveDescriptor persp = fActivePage.getPerspective();
//
// ICommandService commandService = (ICommandService) fWorkbench.getService(ICommandService.class);
// Command command = commandService.getCommand("org.eclipse.ui.window.closePerspective");
//
// HashMap parameters = new HashMap();
// parameters.put(IWorkbenchCommandConstants.WINDOW_CLOSE_PERSPECTIVE_PARM_ID, persp.getId());
//
// ParameterizedCommand pCommand = ParameterizedCommand.generateCommand(command, parameters);
//
// IHandlerService handlerService = (IHandlerService) fWorkbench
// .getService(IHandlerService.class);
// try {
// handlerService.executeCommand(pCommand, null);
// } catch (ExecutionException e1) {
// } catch (NotDefinedException e1) {
// } catch (NotEnabledException e1) {
// } catch (NotHandledException e1) {
// }
//
// }
//
// /**
// * Test opening a perspective with placeholders for multi instance views.
// * The placeholders are added at top level (not in any folder).
// *
// * @since 3.1
// */
// public void testOpenPerspectiveWithMultiViewPlaceholdersAtTopLevel() {
//
// try {
// fWin.getWorkbench().showPerspective(
// PerspectiveWithMultiViewPlaceholdersAtTopLevel.PERSP_ID,
// fWin);
// } catch (WorkbenchException e) {
// fail("Unexpected WorkbenchException: " + e);
// }
//
// ArrayList partIds = facade.getPerspectivePartIds(fActivePage, null);
// assertTrue(partIds.contains("*"));
// assertTrue(partIds.contains(MockViewPart.IDMULT));
// assertTrue(partIds.contains(MockViewPart.IDMULT + ":secondaryId"));
// assertTrue(partIds.contains(MockViewPart.IDMULT + ":*"));
// }
//
// /**
// * Test opening a perspective with placeholders for multi instance views.
// * The placeholders are added in a placeholder folder. This is a regression
// * test for bug 72383 [Perspectives] Placeholder folder error with multiple
// * instance views
// *
// * @since 3.1
// */
// public void testOpenPerspectiveWithMultiViewPlaceholdersInPlaceholderFolder() {
//
// try {
// fWin
// .getWorkbench()
// .showPerspective(
// PerspectiveWithMultiViewPlaceholdersInPlaceholderFolder.PERSP_ID,
// fWin);
// } catch (WorkbenchException e) {
// fail("Unexpected WorkbenchException: " + e);
// }
//
// ArrayList partIds = facade.getPerspectivePartIds(fActivePage,"placeholderFolder");
// assertTrue(partIds.contains("*"));
// assertTrue(partIds.contains(MockViewPart.IDMULT));
// assertTrue(partIds.contains(MockViewPart.IDMULT + ":secondaryId"));
// assertTrue(partIds.contains(MockViewPart.IDMULT + ":*"));
// }
//
// /**
// * Test opening a perspective with placeholders for multi instance views.
// * The placeholders are added at top level (not in any folder).
// *
// * @since 3.1
// */
// public void testOpenPerspectiveWithMultiViewPlaceholdersInFolder() {
// try {
// fWin
// .getWorkbench()
// .showPerspective(
// PerspectiveWithMultiViewPlaceholdersInFolder.PERSP_ID,
// fWin);
// } catch (WorkbenchException e) {
// fail("Unexpected WorkbenchException: " + e);
// }
//
// ArrayList partIds = facade.getPerspectivePartIds(fActivePage,"folder");
// assertTrue(partIds.contains("*"));
// assertTrue(partIds.contains(MockViewPart.IDMULT));
// assertTrue(partIds.contains(MockViewPart.IDMULT + ":secondaryId"));
// assertTrue(partIds.contains(MockViewPart.IDMULT + ":*"));
// }
//
// /**
// * Tests the getNewWizardShortcuts() method.
// *
// * @since 3.1
// */
// public void testGetNewWizardShortcuts() {
// String[] shortcuts = fActivePage.getNewWizardShortcuts();
// assertNotNull(shortcuts);
// assertEquals(0, shortcuts.length);
//
// IWorkbenchWindow win = openTestWindow(IDE.RESOURCE_PERSPECTIVE_ID);
// IWorkbenchPage page = win.getActivePage();
// shortcuts = page.getNewWizardShortcuts();
// List shortcutList = Arrays.asList(shortcuts);
// assertTrue(shortcutList.contains("org.eclipse.ui.wizards.new.folder"));
// assertTrue(shortcutList.contains("org.eclipse.ui.wizards.new.file"));
// }
//
// /**
// * Tests the getShowViewShortcuts() method.
// *
// * @since 3.1
// */
// public void testGetShowViewShortcuts() {
// String[] shortcuts = fActivePage.getShowViewShortcuts();
// assertNotNull(shortcuts);
// assertEquals(0, shortcuts.length);
//
// IWorkbenchWindow win = openTestWindow(IDE.RESOURCE_PERSPECTIVE_ID);
// IWorkbenchPage page = win.getActivePage();
// shortcuts = page.getShowViewShortcuts();
// List shortcutList = Arrays.asList(shortcuts);
// assertTrue(shortcutList.contains(ProjectExplorer.VIEW_ID));
// assertTrue(shortcutList.contains(IPageLayout.ID_OUTLINE));
// assertTrue(shortcutList.contains(IPageLayout.ID_PROP_SHEET));
// assertTrue(shortcutList.contains(IPageLayout.ID_PROBLEM_VIEW));
// }
//
// /**
// * Tests the getPerspectiveShortcuts() method.
// *
// * @since 3.1
// */
// public void testGetPerspectiveShortcuts() {
// String[] shortcuts = fActivePage.getPerspectiveShortcuts();
// assertNotNull(shortcuts);
// assertEquals(0, shortcuts.length);
// // not much of a test
// }
//
// /**
// * Tests the getOpenPerspectives() method.
// *
// * @since 3.1
// */
// public void testGetOpenPerspectives() {
// IPerspectiveDescriptor[] openPersps = fActivePage.getOpenPerspectives();
// assertEquals(1, openPersps.length);
// assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//
// IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
// IPerspectiveDescriptor resourcePersp = reg
// .findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
// fActivePage.setPerspective(resourcePersp);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(2, openPersps.length);
// assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
// assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[1].getId());
//
// IPerspectiveDescriptor emptyPersp = reg
// .findPerspectiveWithId(EmptyPerspective.PERSP_ID);
// fActivePage.setPerspective(emptyPersp);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(2, openPersps.length);
// assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
// assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[1].getId());
//
// fActivePage.closeAllPerspectives(false, false);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(0, openPersps.length);
//
// fActivePage.close();
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(0, openPersps.length);
// }
//
// /**
// * Tests the getSortedPerspectives() method.
// *
// * @since 3.1
// */
// public void testGetSortedPerspectives() {
// IPerspectiveDescriptor[] openPersps = fActivePage
// .getSortedPerspectives();
// assertEquals(1, openPersps.length);
// assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//
// IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
// IPerspectiveDescriptor resourcePersp = reg
// .findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
// fActivePage.setPerspective(resourcePersp);
// openPersps = fActivePage.getSortedPerspectives();
// assertEquals(2, openPersps.length);
// assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
// assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[1].getId());
//
// IPerspectiveDescriptor emptyPersp = reg
// .findPerspectiveWithId(EmptyPerspective.PERSP_ID);
// fActivePage.setPerspective(emptyPersp);
// openPersps = fActivePage.getSortedPerspectives();
// assertEquals(2, openPersps.length);
// assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[0].getId());
// assertEquals(EmptyPerspective.PERSP_ID, openPersps[1].getId());
//
// fActivePage.closeAllPerspectives(false, false);
// openPersps = fActivePage.getSortedPerspectives();
// assertEquals(0, openPersps.length);
//
// fActivePage.close();
// openPersps = fActivePage.getSortedPerspectives();
// assertEquals(0, openPersps.length);
// }
//
// /**
// * Tests the closePerspective method.
// *
// * @since 3.1
// */
// public void testClosePerspective() {
// // TODO: Need to test variants with saveEditors==true
//
// IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
// IPerspectiveDescriptor emptyPersp = reg
// .findPerspectiveWithId(EmptyPerspective.PERSP_ID);
// IPerspectiveDescriptor resourcePersp = reg
// .findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
// fActivePage.setPerspective(resourcePersp);
// IPerspectiveDescriptor[] openPersps = fActivePage.getOpenPerspectives();
// assertEquals(2, openPersps.length);
//
// fActivePage.closePerspective(resourcePersp, false, false);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(1, openPersps.length);
// assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//
// fActivePage.closePerspective(emptyPersp, false, false);
// assertEquals(fActivePage, fWin.getActivePage()); // page not closed
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(0, openPersps.length);
//
// fActivePage.setPerspective(emptyPersp);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(1, openPersps.length);
//
// fActivePage.closePerspective(emptyPersp, false, true);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(0, openPersps.length);
// assertNull(fWin.getActivePage()); // page closed
// }
//
// /**
// * This tests that closing a perspective will not bring a prompt up for
// * {@link org.eclipse.ui.ISaveablePart ISaveablePart} implementations that
// * are returning false for their
// * {@link org.eclipse.ui.ISaveablePart#isSaveOnCloseNeeded()
// * isSaveOnCloseNeeded()} implementation.
// *
// * @see #testCloseAllPerspectivesDoesNotPromptBug272070()
// */
// public void testClosePerspectiveDoesNotPromptBug272070() throws Exception {
// try {
// facade.saveableHelperSetAutomatedResponse(2);
// proj = FileUtil
// .createProject("testClosePerspectiveDoesNotPromptBug272070");
//
// IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
// IPerspectiveDescriptor resourcePersp = reg
// .findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
// // close all perspectives so we start fresh
// fActivePage.closeAllPerspectives(false, false);
// // set the page to the 'Resource' perspective
// fActivePage.setPerspective(resourcePersp);
//
// // create a file and show an editor
// IEditorInput input = new FileEditorInput(FileUtil.createFile(
// "test.mock1", proj));
// MockEditorPart editor = (MockEditorPart) fActivePage.openEditor(
// input, MockEditorPart.ID1);
//
// // mark the editor as being dirty but not requiring saving when
// // closed
// editor.setDirty(true);
// editor.setSaveNeeded(false);
//
// // close the perspective
// fActivePage.closePerspective(resourcePersp, true, false);
// // mark the editor as not dirty, this is important because if the
// // editor is not closed, the test will fail and when JUnit tries to
// // tear down the workbench it will not shutdown because it will
// // prompt about the editor being dirty
// editor.setDirty(false);
// // the editor should have been closed when the perspective was
// // closed
// assertFalse("The editor should've been closed", fActivePage
// .isPartVisible(editor));
//
// // set the page to the 'Resource' perspective
// fActivePage.setPerspective(resourcePersp);
//
// // show a view
// SaveableMockViewPart view = (SaveableMockViewPart) fActivePage
// .showView(SaveableMockViewPart.ID);
//
// // mark the view as being dirty but not requiring saving when closed
// view.setDirty(true);
// view.setSaveNeeded(false);
//
// // close the perspective
// fActivePage.closePerspective(resourcePersp, true, false);
// // like the editor above, we need to mark the view as not being
// // dirty for the same reasons
// view.setDirty(false);
// // the view should have been hidden when the perspective was closed
// assertFalse("The view should be hidden", fActivePage
// .isPartVisible(view));
// } finally {
// facade
// .saveableHelperSetAutomatedResponse(-1);
// }
// }
//
// /**
// * Tests the closeAllPerspectives method.
// *
// * @since 3.1
// */
// public void testCloseAllPerspectives() {
// // TODO: Need to test variants with saveEditors==true
//
// IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
// IPerspectiveDescriptor emptyPersp = reg
// .findPerspectiveWithId(EmptyPerspective.PERSP_ID);
// IPerspectiveDescriptor resourcePersp = reg
// .findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
// fActivePage.setPerspective(resourcePersp);
// IPerspectiveDescriptor[] openPersps = fActivePage.getOpenPerspectives();
// assertEquals(2, openPersps.length);
//
// fActivePage.closeAllPerspectives(false, false);
// assertEquals(fActivePage, fWin.getActivePage()); // page not closed
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(0, openPersps.length);
//
// fActivePage.setPerspective(emptyPersp);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(1, openPersps.length);
//
// fActivePage.closeAllPerspectives(false, true);
// openPersps = fActivePage.getOpenPerspectives();
// assertEquals(0, openPersps.length);
// assertNull(fWin.getActivePage()); // page closed
// }
//
// /**
// * This tests that closing all perspectives will not bring a prompt up for
// * {@link org.eclipse.ui.ISaveablePart ISaveablePart} implementations that
// * are returning false for their
// * {@link org.eclipse.ui.ISaveablePart#isSaveOnCloseNeeded()
// * isSaveOnCloseNeeded()} implementation.
// *
// * @see #testClosePerspectiveDoesNotPromptBug272070()
// */
// public void testCloseAllPerspectivesDoesNotPromptBug272070()
// throws Exception {
// try {
// facade.saveableHelperSetAutomatedResponse(2);
// proj = FileUtil
// .createProject("testCloseAllPerspectivesDoesNotPromptBug272070");
//
// IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
// IPerspectiveDescriptor resourcePersp = reg
// .findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
// // close all perspectives so we start fresh
// fActivePage.closeAllPerspectives(false, false);
// // set the page to the 'Resource' perspective
// fActivePage.setPerspective(resourcePersp);
//
// // create a file and show an editor
// IEditorInput input = new FileEditorInput(FileUtil.createFile(
// "test.mock1", proj));
// MockEditorPart editor = (MockEditorPart) fActivePage.openEditor(
// input, MockEditorPart.ID1);
//
// // mark the editor as being dirty but not requiring saving when
// // closed
// editor.setDirty(true);
// editor.setSaveNeeded(false);
//
// // close all perspectives
// fActivePage.closeAllPerspectives(true, false);
// // mark the editor as not dirty, this is important because if the
// // editor is not closed, the test will fail and when JUnit tries to
// // tear down the workbench it will not shutdown because it will
// // prompt about the editor being dirty
// editor.setDirty(false);
// // the editor should have been closed when the perspective was
// // closed
// assertFalse("The editor should've been closed", fActivePage
// .isPartVisible(editor));
//
// // set the page to the 'Resource' perspective
// fActivePage.setPerspective(resourcePersp);
//
// // show a view
// SaveableMockViewPart view = (SaveableMockViewPart) fActivePage
// .showView(SaveableMockViewPart.ID);
//
// // mark the view as being dirty but not requiring saving when closed
// view.setDirty(true);
// view.setSaveNeeded(false);
//
// // close all perspectives
// fActivePage.closeAllPerspectives(true, false);
// // like the editor above, we need to mark the view as not being
// // dirty for the same reasons
// view.setDirty(false);
// // the view should have been hidden when the perspective was closed
// assertFalse("The view should be hidden", fActivePage
// .isPartVisible(view));
// } finally {
// facade
// .saveableHelperSetAutomatedResponse(-1);
// }
// }
//
// /**
// * Regression test for Bug 76285 [Presentations] Folder tab does not
// * indicate current view. Tests that, when switching between perspectives,
// * the remembered old part correctly handles multi-view instances.
// */
// public void testBug76285() {
// IWorkbenchPage page = fActivePage;
// IPerspectiveDescriptor originalPersp = page.getPerspective();
// IPerspectiveDescriptor resourcePersp = PlatformUI.getWorkbench()
// .getPerspectiveRegistry().findPerspectiveWithId(
// IDE.RESOURCE_PERSPECTIVE_ID);
// // test requires switching between two different perspectives
// assertNotSame(originalPersp, resourcePersp);
//
// int n = 5;
// IViewPart[] views = new IViewPart[n];
// for (int i = 0; i < n; ++i) {
// try {
// views[i] = page.showView(MockViewPart.IDMULT, Integer
// .toString(i), IWorkbenchPage.VIEW_CREATE);
// } catch (PartInitException e) {
// fail(e.getMessage());
// }
// }
// assertEquals(5, page.getViews().length);
// for (int i = 0; i < n; ++i) {
// page.activate(views[i]);
// page.setPerspective(resourcePersp);
// assertFalse(page.getActivePart() instanceof MockViewPart);
// page.setPerspective(originalPersp);
// assertEquals(views[i], page.getActivePart());
// }
// }
//
// /**
// * Tests that IShowEditorInput.showEditorInput is called when a matching
// * editor is found during openEditor, and is not called when a new editor is
// * opened.
// *
// * @since 3.1
// */
// public void testShowEditorInput() throws Exception {
// IWorkbenchPage page = fActivePage;
// proj = FileUtil.createProject("testShowEditorInput");
// IFile file = FileUtil.createFile("a.mock1", proj);
// MockEditorPart part1 = (MockEditorPart) IDE.openEditor(page, file);
// assertFalse(part1.getCallHistory().contains("showEditorInput"));
//
// MockEditorPart part2 = (MockEditorPart) IDE.openEditor(page, file);
// assertTrue(part1 == part2);
// assertTrue(part2.getCallHistory().contains("showEditorInput"));
// }
//
// /**
// * Tests that the openEditor and findEditor variants that accepts match
// * flags work as expected.
// *
// * @since 3.2
// */
// public void testOpenAndFindEditorWithMatchFlags() throws Exception {
// IWorkbenchPage page = fActivePage;
// proj = FileUtil.createProject("testOpenEditorMatchFlags");
// IFile file1 = FileUtil.createFile("a.mock1", proj);
// IFile file2 = FileUtil.createFile("a.mock2", proj);
// FileEditorInput input1 = new FileEditorInput(file1);
// FileEditorInput input2 = new FileEditorInput(file2);
// String id1 = MockEditorPart.ID1;
// String id2 = MockEditorPart.ID2;
//
// // first editor (no match)
// MockEditorPart part1 = (MockEditorPart) page.openEditor(input1, id1,
// true, IWorkbenchPage.MATCH_INPUT);
// assertNotNull(part1);
//
// // same input, same id, matching input (should match part1)
// MockEditorPart part2 = (MockEditorPart) page.openEditor(input1, id1,
// true, IWorkbenchPage.MATCH_INPUT);
// assertTrue(part1 == part2);
//
// // same input, different id, matching input (should match part1)
// MockEditorPart part3 = (MockEditorPart) page.openEditor(input1, id2,
// true, IWorkbenchPage.MATCH_INPUT);
// assertTrue(part1 == part3);
//
// // same input, different id, matching input and id (no match)
// MockEditorPart part4 = (MockEditorPart) page.openEditor(input1, id2,
// true, IWorkbenchPage.MATCH_INPUT | IWorkbenchPage.MATCH_ID);
// assertNotNull(part4);
// assertTrue(part4 != part1);
//
// // same input, same id, matching nothing (no match)
// MockEditorPart part5 = (MockEditorPart) page.openEditor(input1, id1,
// true, IWorkbenchPage.MATCH_NONE);
// assertNotNull(part5);
// assertTrue(part5 != part1);
// assertTrue(part5 != part4);
//
// // different input, same id, matching id (should match part5 instead of
// // part1, because it was active)
// MockEditorPart part6 = (MockEditorPart) page.openEditor(input2, id1,
// true, IWorkbenchPage.MATCH_ID);
// assertTrue(part6 == part5);
//
// // different input, different id, matching input and id (no match)
// MockEditorPart part7 = (MockEditorPart) page.openEditor(input2, id2,
// true, IWorkbenchPage.MATCH_INPUT | IWorkbenchPage.MATCH_ID);
// assertNotNull(part7);
// assertTrue(part7 != part1);
// assertTrue(part7 != part4);
// assertTrue(part7 != part5);
//
// // At this point, there are 4 editors open:
// // part1 (input1, id1), part4 (input1, id2), part5 (input1, id1), and
// // part7 (input2, id2).
// // with part7 active.
//
// // find with MATCH_NONE is always empty
// IEditorReference[] refs = page.findEditors(input1, id1,
// IWorkbenchPage.MATCH_NONE);
// assertEquals(0, refs.length);
//
// // find input1 with MATCH_INPUT finds 3 editors: part1, part4 and part5
// // (in order)
// refs = page.findEditors(input1, null, IWorkbenchPage.MATCH_INPUT);
// assertEquals(3, refs.length);
// assertEquals(part1, refs[0].getPart(true));
// assertEquals(part4, refs[1].getPart(true));
// assertEquals(part5, refs[2].getPart(true));
//
// // find input2 with MATCH_INPUT finds 1 editor: part7
// refs = page.findEditors(input2, null, IWorkbenchPage.MATCH_INPUT);
// assertEquals(1, refs.length);
// assertEquals(part7, refs[0].getPart(true));
//
// // find id1 with MATCH_ID finds 2 editors: part1 and part5 (in order)
// refs = page.findEditors(null, id1, IWorkbenchPage.MATCH_ID);
// assertEquals(2, refs.length);
// assertEquals(part1, refs[0].getPart(true));
// assertEquals(part5, refs[1].getPart(true));
//
// // find id2 with MATCH_ID finds 2 editors: part4 and part7 (with part7
// // first because it was active)
// refs = page.findEditors(null, id2, IWorkbenchPage.MATCH_ID);
// assertEquals(2, refs.length);
// assertEquals(part7, refs[0].getPart(true));
// assertEquals(part4, refs[1].getPart(true));
//
// // find input1 and id1 with MATCH_INPUT and MATCH_ID finds 2 editors:
// // part1 and part5 (in order)
// refs = page.findEditors(input1, id1, IWorkbenchPage.MATCH_INPUT
// | IWorkbenchPage.MATCH_ID);
// assertEquals(2, refs.length);
// assertEquals(part1, refs[0].getPart(true));
// assertEquals(part5, refs[1].getPart(true));
//
// // find input1 and id2 with MATCH_INPUT and MATCH_ID finds 1 editors:
// // part4
// refs = page.findEditors(input1, id2, IWorkbenchPage.MATCH_INPUT
// | IWorkbenchPage.MATCH_ID);
// assertEquals(1, refs.length);
// assertEquals(part4, refs[0].getPart(true));
// }
//
//
// /**
// * Create and hide a single editor, and check it is reflected in the
// * editor references. Check that close still works.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor1() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a.mock1", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor instanceof MockEditorPart);
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
// fActivePage.hideEditor(editorRef);
// assertEquals(0, fActivePage.getEditorReferences().length);
// fActivePage.showEditor(editorRef);
// assertEquals(1, fActivePage.getEditorReferences().length);
// fActivePage.closeAllEditors(true);
// assertEquals(0, fActivePage.getEditorReferences().length);
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create and remove 2 editors. Check that the removed editor
// * is not returned in the list of references. Check that
// * close still works.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor2() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a.mock1", proj);
// IFile file2 = FileUtil.createFile("a.mock2", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor instanceof MockEditorPart);
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
// IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
// assertTrue(editor2 instanceof MockEditorPart);
// IEditorReference editorRef2 = (IEditorReference) fActivePage.getReference(editor2);
//
// fActivePage.hideEditor(editorRef);
// IEditorReference[] refs = fActivePage.getEditorReferences();
// assertEquals(1, refs.length);
// assertEquals(editorRef2, refs[0]);
// fActivePage.showEditor(editorRef);
// refs = fActivePage.getEditorReferences();
// assertEquals(2, refs.length);
//
// fActivePage.hideEditor(editorRef2);
// refs = fActivePage.getEditorReferences();
// assertEquals(1, refs.length);
// fActivePage.hideEditor(editorRef);
// refs = fActivePage.getEditorReferences();
// assertEquals(0, refs.length);
// fActivePage.showEditor(editorRef);
// refs = fActivePage.getEditorReferences();
// assertEquals(editorRef, refs[0]);
// fActivePage.showEditor(editorRef2);
// refs = fActivePage.getEditorReferences();
// assertEquals(2, refs.length);
//
// fActivePage.closeAllEditors(true);
// refs = fActivePage.getEditorReferences();
// assertEquals(0, refs.length);
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create 2 editors and hide one. When added back and then closed, there
// * should only be one editor. Adding back the closed editor should
// * generate a log message and not effect the list of editors.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor3() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a.mock1", proj);
// IFile file2 = FileUtil.createFile("a.mock2", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor instanceof MockEditorPart);
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
// IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
// assertTrue(editor2 instanceof MockEditorPart);
// IEditorReference editorRef2 = (IEditorReference) fActivePage.getReference(editor2);
//
// fActivePage.hideEditor(editorRef2);
// IEditorReference[] refs = fActivePage.getEditorReferences();
// assertEquals(1, refs.length);
// assertEquals(editorRef, refs[0]);
// fActivePage.showEditor(editorRef2);
// fActivePage.closeEditors(new IEditorReference[] { editorRef2 }, true);
// refs = fActivePage.getEditorReferences();
// assertEquals(1, refs.length);
// fActivePage.showEditor(editorRef2);
// assertEquals(1, refs.length);
// assertEquals(getMessage(), 1, logCount);
// assertNotNull(getMessage());
// assertTrue(getMessage().startsWith("adding a disposed part"));
// }
//
// /**
// * Create 2 editors, and remove and show one of them. Trying to
// * add it a second time should not effect the list of editor references.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor4() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a.mock1", proj);
// IFile file2 = FileUtil.createFile("a.mock2", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor instanceof MockEditorPart);
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
// IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
// assertTrue(editor2 instanceof MockEditorPart);
// IEditorReference editorRef2 = (IEditorReference) fActivePage.getReference(editor2);
//
// fActivePage.hideEditor(editorRef2);
// IEditorReference[] refs = fActivePage.getEditorReferences();
// assertEquals(1, refs.length);
// assertEquals(editorRef, refs[0]);
// fActivePage.showEditor(editorRef2);
// refs = fActivePage.getEditorReferences();
// assertEquals(2, refs.length);
// fActivePage.showEditor(editorRef2);
// refs = fActivePage.getEditorReferences();
// assertEquals(2, refs.length);
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create 2 editors that effect the Content Outline view. Make
// * sure that hiding and showing the active editor effects the
// * outline view.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor5() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a1.java", proj);
// IFile file2 = FileUtil.createFile("a2.java", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
// IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
// assertTrue(editor2.getClass().getName().endsWith("CompilationUnitEditor"));
//
// ContentOutline outline = (ContentOutline) fActivePage.showView(IPageLayout.ID_OUTLINE);
// IPage page2 = outline.getCurrentPage();
// fActivePage.activate(editor);
// processEvents();
// IPage page = outline.getCurrentPage();
// assertFalse(page2==page);
//
// assertEquals(getMessage(), 0, logCount);
//
// fActivePage.hideEditor(editorRef);
// assertEquals(page2, outline.getCurrentPage());
// assertEquals(getMessage(), 0, logCount);
//
// fActivePage.showEditor(editorRef);
// assertEquals(page2, outline.getCurrentPage());
// assertEquals(getMessage(), 0, logCount);
//
// fActivePage.activate(editor);
// assertEquals(page, outline.getCurrentPage());
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create one editor. Make sure hiding and showing it effects
// * the outline view, and that when hidden the outline view
// * reflects the default page.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor6() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a1.java", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
//
// ContentOutline outline = (ContentOutline) fActivePage.showView(IPageLayout.ID_OUTLINE);
// IPage defaultPage = outline.getDefaultPage();
// assertNotNull(defaultPage);
//
// processEvents();
// IPage page = outline.getCurrentPage();
// assertFalse(defaultPage==page);
//
// assertEquals(getMessage(), 0, logCount);
// assertEquals(0, partHiddenCount);
// fActivePage.addPartListener(partListener2);
// fActivePage.hideEditor(editorRef);
// processEvents();
//
// assertEquals(1, partHiddenCount);
// assertEquals(editorRef, partHiddenRef);
//
// assertEquals(defaultPage, outline.getCurrentPage());
// //assertEquals(page, outline.getCurrentPage());
// assertEquals(getMessage(), 0, logCount);
//
// assertEquals(0, partVisibleCount);
// fActivePage.showEditor(editorRef);
// processEvents();
// assertEquals(page, outline.getCurrentPage());
// assertEquals(getMessage(), 0, logCount);
// assertEquals(1, partVisibleCount);
// assertEquals(editorRef, partVisibleRef);
//
// fActivePage.activate(editor);
// assertEquals(page, outline.getCurrentPage());
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create one editor. Make sure hiding the editor updates
// * the window title.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor7() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a1.java", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
//
// processEvents();
//
// String firstTitle = fWin.getShell().getText();
//
// assertEquals(getMessage(), 0, logCount);
// assertEquals(0, partHiddenCount);
// fActivePage.addPartListener(partListener2);
// fActivePage.hideEditor(editorRef);
// processEvents();
//
// assertEquals(1, partHiddenCount);
// assertEquals(editorRef, partHiddenRef);
//
// String nextTitle = fWin.getShell().getText();
// String tooltip = editor.getTitleToolTip();
// assertNotNull(tooltip);
// String[] split = Util.split(nextTitle, '-');
// assertEquals(2, split.length);
// String nextTitleRebuilt = split[0] + "- " + tooltip + " -" + split[1];
// assertEquals(firstTitle, nextTitleRebuilt);
//
// assertEquals(0, partVisibleCount);
// fActivePage.showEditor(editorRef);
// processEvents();
// assertEquals(getMessage(), 0, logCount);
// assertEquals(1, partVisibleCount);
// assertEquals(editorRef, partVisibleRef);
// nextTitle = fWin.getShell().getText();
// assertEquals(firstTitle, nextTitle);
//
// fActivePage.activate(editor);
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create one editor. Make sure hiding the editor that is the active part
// * causes another part to become active.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor8() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a1.java", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
//
// ContentOutline outline = (ContentOutline) fActivePage.showView(IPageLayout.ID_OUTLINE);
// IPage defaultPage = outline.getDefaultPage();
// assertNotNull(defaultPage);
// fActivePage.activate(editor);
//
// processEvents();
// IPage page = outline.getCurrentPage();
// assertFalse(defaultPage==page);
//
// partActiveCount = 0;
// partActiveRef = null;
// assertEquals(getMessage(), 0, logCount);
// assertEquals(0, partHiddenCount);
// fActivePage.addPartListener(partListener2);
// fActivePage.hideEditor(editorRef);
// processEvents();
//
// assertEquals(1, partHiddenCount);
// assertEquals(editorRef, partHiddenRef);
// assertEquals(1, partActiveCount);
// assertFalse(partActiveRef == editorRef);
//
// fActivePage.showEditor(editorRef);
//
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create a java editor. Make a change. Validate the enabled state
// * of some commands.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor9() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a1.java", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor.getClass().getName()
// .endsWith("CompilationUnitEditor"));
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
//
// fActivePage.activate(editor);
//
// processEvents();
// ICommandService cs = (ICommandService) fActivePage.getWorkbenchWindow()
// .getService(ICommandService.class);
// Command undo = cs.getCommand("org.eclipse.ui.edit.undo");
// assertTrue(undo.isDefined());
//
// assertFalse(undo.isEnabled());
//
// ITextEditor textEditor = (ITextEditor) editor;
// IDocument doc = textEditor.getDocumentProvider().getDocument(
// textEditor.getEditorInput());
// doc.replace(0, 1, " ");
// fActivePage.saveEditor(editor, false);
//
// processEvents();
// assertTrue(undo.isEnabled());
//
// assertEquals(getMessage(), 0, logCount);
// fActivePage.hideEditor(editorRef);
// processEvents();
//
// assertFalse(undo.isEnabled());
//
// fActivePage.showEditor(editorRef);
//
// assertTrue(undo.isEnabled());
//
// assertEquals(getMessage(), 0, logCount);
// }
//
// /**
// * Create and hide a single editor, and check it is reflected in the
// * editor references. Check that closing the hidden editor still works.
// *
// * @throws Exception
// */
// public void testOpenAndHideEditor10() throws Exception {
// proj = FileUtil.createProject("testOpenAndHideEditor");
// IFile file1 = FileUtil.createFile("a.mock1", proj);
// IEditorPart editor = IDE.openEditor(fActivePage, file1);
// assertTrue(editor instanceof MockEditorPart);
// IEditorReference editorRef = (IEditorReference) fActivePage
// .getReference(editor);
// fActivePage.hideEditor(editorRef);
// assertEquals(0, fActivePage.getEditorReferences().length);
// fActivePage.showEditor(editorRef);
// assertEquals(1, fActivePage.getEditorReferences().length);
// fActivePage.hideEditor(editorRef);
// processEvents();
// fActivePage.closeAllEditors(false);
// assertEquals(getMessage(), 0, logCount);
// assertEquals(0, fActivePage.getEditorReferences().length);
// }
//
// /**
// * Test opening multiple editors for an edge case: one input.
// *
// * openEditors(IWorkbenchPage page, IFile[] inputs)
// */
// public void testOpenEditors1() throws Throwable {
// proj = FileUtil.createProject("testOpenEditors");
// IFile[] inputs = new IFile[1];
// String fileName0 = "test0.txt";
// inputs[0] = FileUtil.createFile(fileName0, proj);
//
// // Check: editor references are returned for each file
// IEditorReference[] refs = IDE.openEditors(fActivePage, inputs);
// assertNotNull(refs);
// assertEquals(1, refs.length);
// assertNotNull(refs[0]);
//
// // Check: the editor is materialized
// IEditorPart editor0 = refs[0].getEditor(false);
// assertNotNull(editor0);
//
// // Check: the first file corresponds to the active editor
// assertEquals(fActivePage.getActiveEditor(), editor0);
//
// // Check: created editor match its input
// assertEquals(editor0.getSite().getId(), fWorkbench.getEditorRegistry()
// .getDefaultEditor(inputs[0].getName()).getId());
//
// // Check: reference's title matches the file name
// assertEquals(fileName0, refs[0].getTitle());
// }
//
// /**
// * Test opening multiple editors for three inputs. Only first editor
// * should be materialized; it also should be the active editor.
// *
// * openEditors(IWorkbenchPage page, IFile[] inputs)
// */
// public void testOpenEditors3() throws Throwable {
// proj = FileUtil.createProject("testOpenEditors");
// IFile[] inputs = new IFile[3];
// String fileName1 = "test1.txt";
// String fileName2 = "test2.txt";
// String fileName3 = "test3.txt";
// inputs[0] = FileUtil.createFile(fileName1, proj);
// inputs[1] = FileUtil.createFile(fileName2, proj);
// inputs[2] = FileUtil.createFile(fileName3, proj);
//
// // Check: editor references are returned for each file
// IEditorReference[] refs = IDE.openEditors(fActivePage, inputs);
// assertNotNull(refs);
// assertEquals(3, refs.length);
// assertNotNull(refs[0]);
// assertNotNull(refs[1]);
// assertNotNull(refs[2]);
//
// // Check: the first file got an editor materialized, rest of the files did not
// IEditorPart editor0 = refs[0].getEditor(false);
// assertNotNull(editor0);
// assertNull(refs[1].getEditor(false));
// assertNull(refs[2].getEditor(false));
//
// // Check: the first file corresponds to the active editor
// assertEquals(fActivePage.getActiveEditor(), editor0);
//
// // Check: created editors match their inputs
// assertEquals(editor0.getSite().getId(), fWorkbench.getEditorRegistry()
// .getDefaultEditor(inputs[0].getName()).getId());
//
// // Check: rest of the editors can be materialized
// IEditorPart editor1 = refs[1].getEditor(true);
// assertNotNull(editor1);
//
// // Check: those editors match their inputs too
// assertEquals(editor1.getSite().getId(), fWorkbench.getEditorRegistry()
// .getDefaultEditor(inputs[1].getName()).getId());
//
// // Check: reference's title matches the file name
// assertEquals(fileName1, refs[0].getTitle());
// assertEquals(fileName2, refs[1].getTitle());
// assertEquals(fileName3, refs[2].getTitle());
// }
//
// /**
// * Test editor reuse when opening multiple editors. The internal editors
// * with matching {id, input} should be reused.
// *
// * openEditors(IWorkbenchPage page, IFile[] inputs)
// */
// public void testOpenEditorsReuse() throws Throwable {
// proj = FileUtil.createProject("testOpenEditors");
//
// String fileName1 = "test1.txt";
// String fileName2 = "test2.txt";
// String fileName3 = "test3.txt";
// int flag = IWorkbenchPage.MATCH_INPUT | IWorkbenchPage.MATCH_ID; // use both matches
//
// // open three files
// IFile[] inputs = new IFile[3];
// inputs[0] = FileUtil.createFile(fileName1, proj);
// inputs[1] = FileUtil.createFile(fileName2, proj);
// inputs[2] = FileUtil.createFile(fileName3, proj);
// IEditorReference[] refs = IDE.openEditors(fActivePage, inputs);
//
// // open two of the same files in mixed order, 1st (materialized) and 3rd (not materialized)
// String editorID = fWorkbench.getEditorRegistry().getDefaultEditor(inputs[0].getName()).getId();
// IEditorInput[] inputs2 = new IEditorInput[] {
// new FileEditorInput(inputs[1]),
// new FileEditorInput(inputs[0]) };
// String[] editorIDs2 = new String [] { editorID, editorID} ;
//
// IEditorReference[] refs2 = fActivePage.openEditors(inputs2, editorIDs2, flag);
// assertNotNull(refs2);
// assertEquals(2, refs2.length);
//
// // now input1 is materialized and has focus
// IEditorPart editor = refs2[0].getEditor(false);
// assertNotNull(editor);
// assertEquals(fActivePage.getActiveEditor(), editor);
//
// // check that the same editor was created
// assertEquals(refs2[0].getEditor(true), refs[1].getEditor(true));
// assertEquals(refs2[1].getEditor(true), refs[0].getEditor(true));
//
// // open a file with different editor IDs, materialized (input0) and non-materialzed (input3)
// String editorIDAlt = fWorkbench.getEditorRegistry().getDefaultEditor("abc.log").getId();
// IEditorInput[] inputs3 = new IEditorInput[] {
// new FileEditorInput(inputs[0]),
// new FileEditorInput(inputs[2]) };
// String[] editorIDs3 = new String [] { editorIDAlt, editorIDAlt} ;
//
// IEditorReference[] refs3 = fActivePage.openEditors(inputs3, editorIDs3, flag);
// assertNotNull(refs3);
// assertEquals(2, refs3.length);
//
// assertFalse(refs2[0].equals(refs[0]));
// assertFalse(refs2[1].equals(refs[2]));
// }
//
// /**
// * A generic test to validate IWorkbenchPage's
// * {@link IWorkbenchPage#setPartState(IWorkbenchPartReference, int)
// * setPartState(IWorkbenchPartReference, int)} method which ensures the
// * prevention of regressing on bug 209333.
// */
// public void testSetPartState() throws Exception {
// // show a view
// IViewPart view = fActivePage.showView(MockViewPart.ID);
//
// // now minimize it
// IViewReference reference = (IViewReference) fActivePage
// .getReference(view);
// fActivePage.setPartState(reference, IWorkbenchPage.STATE_MINIMIZED);
//
// // since it's minimized, it should be a fast view
// assertTrue("A minimized view should be a fast view", facade
// .isFastView(fActivePage, reference));
//
// // try to restore it
// fActivePage.setPartState(reference, IWorkbenchPage.STATE_RESTORED);
// // since it's maximized, it should not be a fast view
// assertFalse("A restored view should not be a fast view", facade
// .isFastView(fActivePage, reference));
// }
//
//}